:root{--bg-base:#0a0e1a;--bg-panel:#111827;--bg-input:#1c2333;--bg-hover:#1e2d44;--border:#1e3a5f;--border-focus:#2d6aa0;--text-primary:#c8d8e8;--text-secondary:#7a9bb5;--text-dim:#4a6a80;--accent:#0d9adb;--accent-hover:color-mix(in srgb, var(--accent), white 20%);--accent-dim:color-mix(in srgb, var(--accent), black 50%);--danger:#e03e3e;--danger-hover:#f55;--warn:#d09020;--ok:#22c55e;--code-bg:#0d1726;--code-text:#48d1cc;--space-xs:4px;--space-sm:8px;--space-md:14px;--space-lg:20px;--font-ui:system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--font-size-sm:.75rem;--font-size-base:.85rem;--font-size-title:.7rem;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--ui-scale:1;--sidebar-width:calc(280px * var(--ui-scale));--text:var(--text-primary);--bg-elevated:var(--bg-panel);--surface-2:var(--bg-hover)}:root[data-theme=light]{--bg-base:#f4f6fa;--bg-panel:#fff;--bg-input:#f0f3f8;--bg-hover:#e6ecf3;--border:#d4dce6;--border-focus:#98b8db;--text-primary:#1a2940;--text-secondary:#4a6080;--text-dim:#8395a8;--code-bg:#eef2f7;--code-text:#1976a4}*,:before,:after{box-sizing:border-box;margin:0;padding:0}[hidden]{display:none!important}html,body{height:100%;overflow:hidden}body{font-family:var(--font-ui);font-size:var(--font-size-base);color:var(--text-primary);background:var(--bg-base)}body.gm-view{grid-template-columns:var(--sidebar-width) 1fr;grid-template-rows:100vh;display:grid}#sidebar{background:var(--bg-panel);border-right:1px solid var(--border);scrollbar-width:thin;scrollbar-color:var(--border) transparent;z-index:100;flex-direction:column;gap:1px;display:flex;position:relative;overflow:hidden auto}#main-area{background:#000;position:relative;overflow:hidden}#canvas-wrapper{cursor:grab;width:100%;height:100%;position:relative;overflow:hidden}.empty-canvas{z-index:60;text-align:center;background:var(--bg-base,#0a0e1a);cursor:default;-webkit-user-select:none;user-select:none;flex-direction:column;justify-content:center;align-items:center;gap:.35rem;padding:2rem;display:flex;position:absolute;inset:0}.empty-canvas[hidden]{display:none}.empty-canvas__logo{object-fit:contain;opacity:.92;filter:drop-shadow(0 4px 18px #00000080);width:128px;height:128px;margin-bottom:.75rem}.empty-canvas__title{color:var(--text-primary,#e8ecf4);letter-spacing:.01em;margin:0;font-size:1.4rem;font-weight:600}.empty-canvas__body{max-width:30rem;color:var(--text-secondary,#7a9bb5);margin:0;font-size:.95rem}.empty-canvas__hint{max-width:30rem;color:var(--text-secondary,#7a9bb5);margin:.5rem 0 0;font-size:.9rem}.empty-canvas__plus{background:var(--ok,#22c55e);color:#fff;border-radius:5px;justify-content:center;align-items:center;width:1.25em;height:1.25em;font-weight:700;line-height:1;display:inline-flex;transform:translateY(.1em)}.player-pip-frame{aspect-ratio:16/9;background:var(--bg-panel,#11151f);z-index:50;resize:horizontal;border:1px solid #ffffff24;border-radius:8px;flex-direction:column;width:33%;min-width:240px;max-width:80%;display:flex;position:absolute;overflow:hidden;box-shadow:0 6px 22px #0000008c}.player-pip-header{background:var(--bg-card,#1a1f2e);cursor:move;-webkit-user-select:none;user-select:none;touch-action:none;border-bottom:1px solid #ffffff14;align-items:center;gap:6px;padding:4px 8px;display:flex}.player-pip-title{color:var(--text-secondary,#9aa3b2);letter-spacing:.02em;flex:1;font-size:.78rem}.player-pip-chrome-btn{width:22px;height:22px;color:var(--text-secondary,#9aa3b2);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:4px;flex:none;justify-content:center;align-items:center;transition:background .12s,color .12s,border-color .12s;display:inline-flex}.player-pip-chrome-btn:hover{color:var(--text-primary,#e4e8f0);background:#ffffff0d;border-color:#ffffff1f}.player-pip-iframe{background:#000;border:none;flex:1;width:100%;display:block}.player-pip-show-btn{z-index:50;color:var(--text-secondary,#9aa3b2);background:var(--bg-card,#1a1f2e);cursor:pointer;border:1px solid #ffffff24;border-radius:999px;align-items:center;gap:6px;padding:6px 12px;font-size:.82rem;transition:background .12s,color .12s,border-color .12s;display:inline-flex;position:absolute;bottom:12px;left:12px;box-shadow:0 2px 10px #00000073}.player-pip-show-btn:hover{color:var(--text-primary,#e4e8f0);background:var(--bg-panel,#11151f);border-color:#ffffff38}.gm-canvas-undo-bar{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:12;opacity:.55;pointer-events:auto;background:#14182473;border:1px solid #ffffff26;border-radius:999px;gap:6px;padding:4px 6px;transition:opacity .12s;display:flex;position:absolute;top:10px;left:50%;transform:translate(-50%)}.gm-canvas-undo-bar:hover{opacity:1}.gm-canvas-undo-btn{color:#ffffffe6;cursor:pointer;background:#ffffff0a;border:1px solid #fff3;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;padding:0;display:flex}.gm-canvas-undo-btn:hover:not(:disabled){filter:brightness(1.15);background:#ffffff1f}.gm-canvas-undo-btn:disabled{cursor:default;color:#ffffff40;border-color:#ffffff14}.offscreen-indicator{border-radius:var(--radius-md);z-index:50;cursor:pointer;-webkit-user-select:none;user-select:none;pointer-events:auto;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);white-space:nowrap;background:#000000b3;border:1px solid;align-items:center;gap:6px;padding:4px 8px;font-size:.7rem;display:flex;position:absolute;transform:translate(-50%,-50%)}.offscreen-indicator:hover{background:#000000e6}.offscreen-indicator__arrow{transform-origin:50%}.offscreen-indicator--player{color:#ff8c00}.offscreen-indicator--projector{color:#22c55e}.reset-view-btn{color:var(--text,#fff);border-radius:var(--radius-md);z-index:50;cursor:pointer;-webkit-user-select:none;user-select:none;pointer-events:auto;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:.55;background:#0000008c;border:1px solid #ffffff40;align-items:center;gap:6px;padding:5px 9px;font-size:.7rem;transition:opacity .12s,background .12s;display:flex;position:absolute;bottom:12px;right:12px}.reset-view-btn:hover{opacity:1;background:#000000d9}.reset-view-btn__label{white-space:nowrap}#canvas-wrapper canvas{width:100%;height:100%;position:absolute;inset:0}#fog-canvas{pointer-events:none}#fog-canvas.fog-draw{pointer-events:auto;z-index:2;cursor:crosshair}#viewport-canvas{pointer-events:none;z-index:3}.marker-overlay{pointer-events:none;z-index:5;position:absolute;inset:0;overflow:hidden}body.player-view .marker-overlay,body.projector-view .marker-overlay{z-index:5;position:fixed;inset:0}.marker-overlay-item{pointer-events:none;width:0;height:0;position:absolute}.marker-label{top:calc(var(--icon-half-h,0px) + 4px);color:#fff;font:bold 11px var(--font-system,system-ui, sans-serif);white-space:nowrap;text-shadow:0 1px #000000e6,0 -1px #000000e6,1px 0 #000000e6,-1px 0 #000000e6,0 0 3px #000c;pointer-events:none;-webkit-user-select:none;user-select:none;position:absolute;left:0;transform:translate(-50%)}.marker-label--locked{opacity:.55}.marker-handle{color:#fffffff2;pointer-events:auto;-webkit-user-select:none;user-select:none;cursor:pointer;touch-action:none;background:#141824d9;border:1.5px solid #ffffff8c;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;transition:background .12s,color .12s,transform 80ms;display:flex;position:absolute;transform:translate(-50%,-50%);box-shadow:0 2px 4px #0009}.marker-handle:hover{color:var(--accent,#fff);background:#283246f2;border-color:#ffffffd9}.marker-handle:active{transform:translate(-50%,-50%)scale(.94)}.marker-handle svg{display:block}.marker-handle--move{top:calc(-1 * var(--icon-half-h,0px) - 4px);left:calc(-1 * var(--icon-half-w,0px) - 4px);cursor:move}.marker-badges{top:calc(-1 * var(--icon-half-h,0px) - 4px);left:calc(-1 * var(--icon-half-w,0px) + 13px);pointer-events:none;gap:4px;display:flex;position:absolute;transform:translateY(-50%)}.marker-badge{color:#fff;pointer-events:auto;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:manipulation;background:#141824d9;border:1.5px solid #ffffff8c;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;padding:0;transition:filter .12s,transform 80ms;display:flex;box-shadow:0 2px 4px #0009}.marker-badge:hover{filter:brightness(1.15)}.marker-badge:active{transform:scale(.94)}.marker-badge svg{display:block}.marker-handle--lock{top:calc(-1 * var(--icon-half-h,0px) - 4px);left:calc(-1 * var(--icon-half-w,0px) - 4px);pointer-events:none;cursor:default;opacity:.4}.marker-handle--lock:hover{filter:none;background:#141824d9;border-color:#ffffff8c}.marker-handle--lock:active{transform:translate(-50%,-50%)}.marker-overlay-item--locked .marker-badge{pointer-events:none;cursor:default;opacity:.4}.marker-overlay-item--locked .marker-badge:hover{filter:none}.marker-overlay-item--locked .marker-badge:active{transform:translate(0)}.marker-overlay-rect{pointer-events:none;transition:background-color .12s;position:absolute}.marker-overlay-rect--selected{outline:2px dashed var(--rect-color,#ffffffe6);outline-offset:-1px;background:#ffffff0d}.marker-overlay-rect .marker-handle{background:var(--rect-color,#141824d9);border-color:#ffffffb3}.marker-overlay-rect .marker-handle:hover{filter:brightness(1.15);border-color:#fffffff2}.marker-overlay-rect .marker-handle--rect-resize,.marker-overlay-rect .marker-handle--rect-ratio-lock,.marker-overlay-rect .marker-handle--rect-aspect,.marker-overlay-rect .marker-handle--rect-maximise,.marker-overlay-rect .marker-handle--rect-show-grid{background:#141824d9}.marker-overlay-rect .marker-handle--rect-resize:hover,.marker-overlay-rect .marker-handle--rect-ratio-lock:hover,.marker-overlay-rect .marker-handle--rect-aspect:hover,.marker-overlay-rect .marker-handle--rect-maximise:hover,.marker-overlay-rect .marker-handle--rect-show-grid:hover{background:#283246f2}.marker-overlay-rect .marker-handle--rect-show-grid.marker-handle--rect-show-grid--on,.marker-overlay-rect .marker-handle--rect-ratio-lock.marker-handle--rect-ratio-lock--engaged,.marker-overlay-rect .marker-handle--rect-aspect.marker-handle--rect-aspect--current{background:#5af07ad9}.marker-handle--rect-move{cursor:move;top:0;left:0}.marker-handle--rect-resize{cursor:nwse-resize;border-width:2px;border-color:#5af07ad9;border-radius:6px;top:100%;left:100%}.marker-handle--rect-show-grid{cursor:pointer;top:30px;left:0}.marker-handle--rect-show-grid--on{color:#0a0e1a;background:#5af07ad9;border-color:#fff}.marker-handle--rect-view-broadcast{cursor:pointer;top:0;left:30px}.marker-handle--rect-view-broadcast--off{color:#fff;background:#dc2626eb;border-color:#fff}.marker-handle--rect-view-broadcast--no-target{opacity:.45;cursor:default}.marker-handle--rect-ratio-lock{cursor:pointer;top:calc(100% - 30px);left:100%}.marker-handle--rect-ratio-lock--engaged{color:#0a0e1a;background:#5af07ad9;border-color:#fff}.marker-handle--rect-maximise{cursor:pointer;top:0;left:60px}.marker-handle--rect-aspect{cursor:pointer;top:calc(100% - 60px);left:100%}.marker-handle--rect-aspect--current{color:#0a0e1a;background:#5af07ad9;border-color:#fff}.marker-handle--rect-aspect--ghosted{color:#ffffffb3;background:#5af07a73;border-color:#fff9}.marker-handle--rect-aspect--disabled{opacity:.45;cursor:not-allowed}.marker-selection-ring{width:calc(2 * var(--icon-half-w,0px) + 10px);height:calc(2 * var(--icon-half-h,0px) + 10px);pointer-events:none;z-index:-1;border:2px dashed #ffffffe6;border-radius:8px;position:absolute;top:0;left:0;transform:translate(-50%,-50%);box-shadow:0 0 6px #00000080}.marker-handle--resize{top:calc(var(--icon-half-h,0px) + 4px);left:calc(var(--icon-half-w,0px) + 4px);cursor:nwse-resize}.marker-handle--rotate{top:calc(-1 * var(--icon-half-h,0px) - 32px);cursor:grab;left:0}.marker-handle--rotate:active{cursor:grabbing}.marker-rotate-stem{top:calc(-1 * var(--icon-half-h,0px) - 20px);pointer-events:none;z-index:1;border-left:2px solid #5af07a99;width:0;height:20px;position:absolute;left:50%;transform:translate(-50%)}.marker-handle--flip-v{top:calc(-1 * var(--icon-half-h,0px) - 14px);left:0}.marker-handle--flip-h{top:0;left:calc(var(--icon-half-w,0px) + 4px)}.marker-handle--flip-v.is-active,.marker-handle--flip-h.is-active{color:#0a0e1a;background:#5af07ad9;border-color:#5af07af2}.marker-handle--delete{top:calc(var(--icon-half-h,0px) + 4px);left:calc(-1 * var(--icon-half-w,0px) - 4px);color:#ffc4c4;cursor:pointer;border-color:#dc5050d9}.marker-handle--delete:hover{color:#fff;background:#b42828f2;border-color:#ff8080}.fog-delete-handle{color:#ffc4c4;pointer-events:auto;-webkit-user-select:none;user-select:none;cursor:pointer;z-index:6;background:#141824d9;border:1.5px solid #dc5050d9;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;padding:0;transition:background .12s,color .12s,transform 80ms;display:flex;position:absolute;transform:translate(-50%,-50%);box-shadow:0 2px 4px #0009}.fog-delete-handle:hover{color:#fff;background:#b42828f2;border-color:#ff8080}.fog-delete-handle:active{transform:translate(-50%,-50%)scale(.94)}.fog-delete-handle svg{display:block}.fog-delete-handle[hidden]{display:none}#scaled-view-projection-row{grid-template-columns:auto}#scaled-view-projection-picker,#scaled-view-projection-picker .editable-select{min-width:0}#projector-viewport-canvas{z-index:4;pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.projector-rect-handle{color:#fff;cursor:grab;z-index:5;pointer-events:auto;background:#22c55eeb;border:1px solid #fff;border-radius:4px;justify-content:center;align-items:center;width:26px;height:26px;margin:-13px 0 0 -13px;padding:0;display:flex;position:absolute;top:0;left:0;box-shadow:0 1px 3px #00000080}.projector-rect-handle:active{cursor:grabbing}.projector-rect-handle[hidden]{display:none}.projector-status{color:var(--text-secondary);font-size:.75rem;font-family:var(--font-mono);margin:0;line-height:1.4}body.player-view{touch-action:none;overscroll-behavior:none;background:#000;width:100vw;height:100vh;position:relative}body.player-view #renderer-canvas{width:100%;height:100%;position:absolute;inset:0}#transition-canvas{pointer-events:none;z-index:10;width:100%;height:100%;display:block;position:fixed;inset:0}#player-grid{pointer-events:none;z-index:8;width:100%;height:100%;display:block;position:fixed;inset:0}#status{bottom:var(--space-lg);padding:var(--space-sm) var(--space-md);border:1px solid var(--border);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:var(--font-size-sm);color:var(--text-secondary);z-index:20;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0a0e1ad9;position:absolute;left:50%;transform:translate(-50%)}.connect-panel{justify-content:center;align-items:center;gap:var(--space-lg);z-index:30;background:#0a0e1af2;flex-direction:column;display:flex;position:absolute;inset:0}.connect-title{letter-spacing:.15em;color:var(--text-primary);text-transform:uppercase;font-size:1.4rem;font-weight:300}.connect-sub{color:var(--text-secondary);font-size:var(--font-size-base)}.connect-byline{color:var(--text-dim);letter-spacing:.05em;text-transform:none;font-weight:400}.brand{align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-md) var(--space-sm);flex-direction:row;line-height:1;display:flex;position:relative}.brand-icon{cursor:pointer;border-radius:6px;flex:none;width:40px;height:40px;transition:transform .15s ease-out;display:block}.brand-text{flex-direction:column;align-items:flex-start;display:flex}.brand-menu-btn{width:32px;height:32px;color:var(--text-dim);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;flex:none;justify-content:center;align-items:center;margin-left:auto;font-size:18px;line-height:1;transition:background-color .15s,color .15s,border-color .15s;display:inline-flex}.brand-menu-btn:hover{background:var(--bg-hover,#ffffff0f);color:var(--text-primary);border-color:var(--border)}.brand-menu-btn[aria-expanded=true]{background:var(--bg-hover,#ffffff14);color:var(--text-primary);border-color:var(--border)}.gm-menu{top:100%;right:var(--space-md);z-index:50;background:var(--bg-panel,#161a26);border:1px solid var(--border);border-radius:6px;flex-direction:column;min-width:180px;margin-top:4px;padding:4px 0;display:flex;position:absolute;box-shadow:0 6px 20px #0006}.gm-menu[hidden]{display:none}.gm-menu-item{text-align:left;width:100%;font:inherit;color:var(--text-primary);cursor:pointer;background:0 0;border:0;align-items:center;gap:10px;padding:8px 14px;display:flex}.gm-menu-icon{width:16px;height:16px;color:var(--text-dim);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.gm-menu-icon svg{width:16px;height:16px;display:block}.gm-menu-item:hover:not(:disabled) .gm-menu-icon{color:inherit}.gm-menu-item--danger .gm-menu-icon{color:var(--danger)}.gm-menu-item--danger:hover:not(:disabled) .gm-menu-icon{color:var(--danger-hover)}.gm-menu-label{flex:1}.gm-menu-item:hover:not(:disabled){background:var(--bg-hover,#ffffff0f)}.gm-menu-item--disabled,.gm-menu-item:disabled{color:var(--text-dim);cursor:not-allowed;opacity:.6}.gm-menu-item--subtle{opacity:.6}.gm-menu-item--subtle:hover:not(:disabled){opacity:1}.gm-menu-item--danger{color:var(--danger)}.gm-menu-item--danger:hover:not(:disabled){color:var(--danger-hover);background:#e03e3e1f}.gm-menu-sep{background:var(--border);height:1px;margin:4px 0}.brand-name{letter-spacing:.06em;color:var(--text-primary);font-size:1.25rem;font-weight:600}.brand-byline{letter-spacing:.18em;text-transform:uppercase;color:var(--text-dim);margin-top:4px;font-size:.7rem}.connect-row{gap:var(--space-sm);display:flex}.room-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-mono);padding:var(--space-sm) var(--space-md);outline:none;width:260px;font-size:1rem}.room-input:focus{border-color:var(--border-focus)}.panel{border-bottom:1px solid var(--border);flex-direction:column;display:flex}.panel-header{position:relative}.panel-title{letter-spacing:.14em;text-transform:uppercase;color:var(--text-secondary);border:none;border-bottom:1px solid var(--border);text-align:left;cursor:pointer;width:100%;padding:var(--space-sm) var(--space-md);background:#1e3a5f59;justify-content:space-between;align-items:center;font-size:.75rem;font-weight:700;display:flex;position:relative}.panel-title:hover{color:var(--text-primary);background:#1e3a5f8c}.panel-title:after{content:"▸";right:var(--space-md);flex-shrink:0;font-size:.65rem;transition:transform .18s;position:absolute;top:50%;transform:translateY(-50%)}.panel-title[aria-expanded=true]:after{transform:translateY(-50%)rotate(90deg)}#map-panel .panel-title{justify-content:flex-start;gap:0;padding-right:56px}.pack-name-display{color:#fff;text-transform:none;letter-spacing:.01em;font-weight:700}.panel-edit-btn{right:calc(var(--space-md) + 16px);z-index:2;border-radius:var(--radius-sm);width:24px;height:24px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.panel-edit-btn:hover{color:var(--text-primary);background:#ffffff14}.pack-name-edit-input{left:var(--space-md);right:calc(var(--space-md) + 44px);z-index:3;background:var(--bg-input);border:1px solid var(--border-focus,var(--accent));border-radius:var(--radius-sm);color:#fff;font-family:var(--font-ui);font-size:var(--font-size-sm);outline:none;padding:4px 6px;position:absolute;top:50%;transform:translateY(-50%)}.panel-count-badge{letter-spacing:.02em;color:var(--text-secondary);border:1px solid var(--border);pointer-events:none;white-space:nowrap;background:#00000047;border-radius:9px;padding:2px 7px;font-size:.68rem;font-weight:700;line-height:1;position:absolute;top:50%;right:30px;transform:translateY(-50%)}.panel-body{gap:var(--space-sm);padding:var(--space-sm) var(--space-md) var(--space-md);flex-direction:column;display:flex}.subpanel{border:1px solid var(--border);background:#0000001f;border-radius:6px;overflow:hidden}.subpanel-title{letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary);text-align:left;cursor:pointer;width:100%;padding:var(--space-sm) var(--space-md);background:#1e3a5f40;border:none;justify-content:space-between;align-items:center;font-size:.68rem;font-weight:700;display:flex;position:relative}.subpanel-title:hover{color:var(--text-primary);background:#1e3a5f73}.subpanel-title:after{content:"▸";right:var(--space-md);font-size:.6rem;transition:transform .18s;position:absolute;top:50%;transform:translateY(-50%)}.subpanel-title[aria-expanded=true]:after{transform:translateY(-50%)rotate(90deg)}.subpanel-body{gap:var(--space-sm);padding:var(--space-sm) var(--space-md) var(--space-md);flex-direction:column;display:flex}.connections-join{flex-direction:column;align-items:center;gap:6px;display:flex}.connections-qr{box-sizing:border-box;background:#fff;border-radius:6px;width:160px;height:160px;padding:6px}.connections-url{color:var(--text-secondary);word-break:break-all;text-align:center;margin:0;font-size:.7rem}.connections-summary{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.connections-summary li{color:var(--text-secondary);background:#ffffff08;border-radius:4px;justify-content:space-between;align-items:center;padding:4px 8px;font-size:.75rem;display:flex}.connections-summary li .conn-count{color:var(--text-primary);font-weight:700}.connections-summary li .conn-sub{opacity:.75;font-size:.68rem;font-weight:400}.connections-summary li.conn-empty{opacity:.6;justify-content:center;font-style:italic}#qr-container{padding:var(--space-xs);cursor:pointer;border-radius:var(--radius-sm);outline:none;flex-direction:row;justify-content:center;align-items:stretch;gap:6px;display:flex}#qr-container:focus-visible{box-shadow:0 0 0 2px var(--accent-dim)}#qr-container canvas{border-radius:var(--radius-sm);pointer-events:none}.qr-copy-btn{border-radius:var(--radius-sm);color:#0a0e1a;cursor:pointer;background:#f0f3f8;border:1px solid #f0f3f8;justify-content:center;align-self:stretch;align-items:center;width:28px;padding:0;transition:background-color .15s,color .15s,border-color .15s;display:inline-flex}.qr-copy-btn:hover{border-color:var(--accent,#fff);color:var(--accent,#0a0e1a);background:#fff}.broker-error{align-items:center;gap:var(--space-xs);padding:var(--space-sm);border-radius:var(--radius-sm);color:var(--text-dim);text-align:center;background:#c0392b14;border:1px solid #c0392b80;flex-direction:column;font-size:.85em;display:flex}.broker-error[hidden]{display:none}.broker-error svg{color:#dc645af2}.broker-error strong{color:var(--text)}.broker-error p{margin:0;line-height:1.4}.session-actions{gap:var(--space-xs);flex-direction:column;display:flex}.session-meta{font-size:var(--font-size-sm);color:var(--text-secondary);text-align:center}.btn{padding:var(--space-sm) var(--space-md);border:1px solid var(--border);border-radius:var(--radius-md);font-family:var(--font-ui);font-size:var(--font-size-sm);cursor:pointer;white-space:nowrap;justify-content:center;align-items:center;font-weight:500;text-decoration:none;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.btn--primary{background:var(--accent-dim);border-color:var(--accent);color:var(--accent-hover)}.btn--primary:hover{background:var(--accent);color:#fff}.btn--ghost{color:var(--text-secondary);background:0 0}.btn--ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn--danger{border-color:var(--danger);color:var(--danger);background:0 0}.btn--danger:hover{background:var(--danger);color:#fff}.btn--sm{padding:var(--space-xs) var(--space-sm);font-size:.7rem}.btn--active{background:var(--accent-dim)!important;border-color:var(--accent)!important;color:var(--accent-hover)!important}.upload-label{text-align:center;cursor:pointer}.btn-row{gap:var(--space-xs);display:flex}.btn-row .btn{text-align:center;cursor:pointer;flex:1}select{appearance:none;background-color:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);padding:var(--space-sm) 28px var(--space-sm) var(--space-sm);font-size:var(--font-size-base);cursor:pointer;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' fill='none' stroke='%23999' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><polyline points='3,5 6,8 9,5'/></svg>");background-position:right 10px center;background-repeat:no-repeat;background-size:12px;outline:none}select:focus{border-color:var(--border-focus)}.select-full{width:100%}option.select-option--add{color:#4ade80;font-weight:600}.editable-select{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;font-size:var(--font-size-base);align-items:stretch;display:flex;position:relative}.editable-select--open,.editable-select:focus-within{border-color:var(--border-focus)}.editable-select__native{opacity:0;pointer-events:none;width:0;height:0;position:absolute}.editable-select__value{min-width:0;color:var(--text-primary);font:inherit;padding:var(--space-sm);background:0 0;border:none;outline:none;flex:1}.editable-select__value[readonly]{cursor:default}.editable-select__chevron{border:none;border-left:1px solid var(--border);width:28px;color:var(--text-primary);cursor:pointer;background:0 0;justify-content:center;align-items:center;padding:0;display:flex}.editable-select__chevron:hover{color:var(--accent)}.editable-select__menu{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);z-index:100;max-height:280px;margin:0;padding:4px 0;list-style:none;position:absolute;top:calc(100% + 2px);left:0;right:0;overflow-y:auto;box-shadow:0 4px 12px #00000059}.editable-select__opt{cursor:pointer;color:var(--text-primary);font-size:var(--font-size-base);padding:6px 10px}.editable-select__opt:hover{background:var(--bg-hover)}.editable-select__opt--selected{background:var(--accent-dim);color:var(--accent-hover)}.editable-select__opt--sentinel{color:#4ade80;font-weight:600}.editable-select__opt--placeholder{color:var(--text-secondary);font-style:italic}.editable-select__opt--missing{color:#f59e0b}.editable-select__opt--missing.editable-select__opt--selected{color:#fbbf24}.editable-select__value--missing{color:#f59e0b}.transition-params-container{margin-top:var(--space-xs);flex-direction:column;gap:1px;display:flex}.filter-params-container{flex-direction:column;gap:1px;display:flex}.filter-empty{font-size:var(--font-size-sm);color:var(--text-dim);text-align:center;padding:var(--space-sm)}.picker-row{align-items:stretch;gap:var(--space-xs);width:100%;display:flex}.picker-row__select{flex:auto;min-width:0}.picker-row__add{border-radius:var(--radius-sm);color:#4ade80;cursor:pointer;padding:0 var(--space-sm);background:#22c55e14;border:1px solid #22c55e73;flex:none;justify-content:center;align-items:center;transition:background .12s,color .12s,border-color .12s;display:inline-flex}.picker-row__add:hover{color:#86efac;background:#22c55e29;border-color:#4ade80d9}.picker-row__add:active{background:#22c55e40}.filter-affect-markers{align-items:center;gap:var(--space-xs);padding:var(--space-xs) 0;font-size:var(--font-size-sm);color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;display:flex}.filter-affect-markers input[type=checkbox]{cursor:pointer;margin:0}.filter-group{border-top:1px solid var(--border)}.filter-group-header{width:100%;color:var(--text-secondary);font-size:var(--font-size-sm);letter-spacing:.08em;text-transform:uppercase;padding:var(--space-sm) var(--space-xs);cursor:pointer;text-align:left;align-items:center;gap:var(--space-xs);background:0 0;border:none;font-weight:600;display:flex}.filter-group-header:before{content:"▸";font-size:.6rem;transition:transform .15s}.filter-group-header[aria-expanded=true]:before{transform:rotate(90deg)}.filter-group-header:hover{color:var(--text-primary)}.filter-group-body{padding:var(--space-xs) 0}.param-row{align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-sm);grid-template-columns:1fr auto auto;min-height:28px;display:grid}.param-row label{font-size:var(--font-size-sm);color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.param-row--stacked{padding:var(--space-xs) 0;min-height:unset;flex-direction:column;align-items:stretch;gap:3px;display:flex}.param-row--stacked label{font-size:var(--font-size-sm);color:var(--text-secondary);text-align:left;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.param-controls{align-items:center;gap:var(--space-xs);display:flex}.param-controls input[type=range]{min-width:0;accent-color:var(--accent);cursor:pointer;flex:1}.param-row input[type=range]{width:90px;accent-color:var(--accent);cursor:pointer;grid-column:2}.bg-controls{align-items:center;gap:var(--space-xs);display:flex}.bg-fx-btn{width:28px;height:28px;color:var(--text-secondary);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:4px;justify-content:center;align-items:center;padding:0;transition:background .12s,color .12s,border-color .12s;display:inline-flex}.bg-fx-btn:hover{background:var(--accent-dim);color:var(--accent);border-color:var(--accent)}.bg-fx-btn[aria-expanded=true]{background:var(--accent);color:#fff;border-color:var(--accent)}.bg-fx-btn--active:after{content:"";background:var(--accent);width:6px;height:6px;box-shadow:0 0 0 1.5px var(--bg-card,#1a1f2e);border-radius:50%;margin-top:18px;margin-left:16px;position:absolute}.bg-fx-btn{position:relative}.fx-popover{z-index:200;background:var(--bg-card,#1a1f2e);border:1px solid #ffffff1f;border-radius:6px;flex-direction:column;gap:2px;min-width:160px;padding:4px;display:flex;position:absolute;box-shadow:0 4px 16px #00000073}.side-panel{top:0;left:var(--sidebar-width);height:100vh;width:calc(340px * var(--ui-scale));max-width:calc(100vw - var(--sidebar-width));background:var(--bg-card,#1a1f2e);z-index:90;border-right:1px solid #ffffff1f;flex-direction:column;transition:transform .22s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;transform:translate(-100%);box-shadow:4px 0 18px #00000073}.side-panel.is-open{transform:translate(0)}.side-panel__header{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:#ffffff05;border-bottom:1px solid #ffffff14;display:flex}.side-panel__title{font-size:var(--font-size-md,.95rem);color:var(--text-primary,#e4e8f0);letter-spacing:.02em;flex:1;margin:0;font-weight:600}.side-panel__close{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;background:0 0;border:1px solid #0000;flex:none;justify-content:center;align-items:center;transition:background .12s,color .12s,border-color .12s;display:inline-flex}.side-panel__close:hover{color:var(--text-primary);background:#ffffff0a;border-color:#ffffff1f}.side-panel__body{padding:var(--space-md);gap:var(--space-sm);flex-direction:column;flex:1;display:flex;overflow-y:auto}.side-panel--mobile{border-right:none;width:100vw;max-width:100vw;left:0}.fx-popover-option{text-align:left;color:var(--text-primary);font-size:var(--font-size-sm);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:6px 10px}.fx-popover-option:hover{background:var(--accent-dim)}.fx-popover-option--selected{background:var(--accent);color:#fff}.fx-popover-option--selected:hover{background:var(--accent-hover)}.fx-popover-options{flex-direction:column;gap:2px;display:flex}.fx-popover-params{border-top:1px solid #ffffff14;flex-direction:column;gap:6px;min-width:200px;margin-top:6px;padding-top:6px;display:flex}.fx-popover-params[hidden]{display:none}.fx-popover-params .fog-brush-row{margin:0}.marker-badge-tooltip{color:var(--text-primary);pointer-events:none;white-space:nowrap;z-index:9999;background:#000000d1;border:1px solid #ffffff1f;border-radius:4px;padding:3px 8px;font-size:11px;position:fixed}.param-hint{font-size:var(--font-size-sm);color:var(--text-dim);font-weight:400}.param-value{font-family:var(--font-mono);font-size:var(--font-size-sm);color:var(--accent);text-align:right;min-width:36px}.param-number{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:54px;color:var(--text-primary);font-family:var(--font-mono);font-size:var(--font-size-sm);padding:1px var(--space-xs);text-align:right;-moz-appearance:textfield;outline:none}.param-number:focus{border-color:var(--border-focus)}.param-number::-webkit-inner-spin-button{opacity:.6}.param-number::-webkit-outer-spin-button{opacity:.6}.param-row input[type=color]{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:0 0;grid-column:2/span 2;width:32px;height:24px;padding:2px}.param-row select{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--font-size-sm);padding:2px var(--space-xs);cursor:pointer;grid-column:2/span 2}.param-row--toggle{grid-template-columns:1fr auto}.toggle-switch{cursor:pointer;width:36px;height:20px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{background:var(--bg-input);border:1px solid var(--border);border-radius:20px;transition:background .2s;position:absolute;inset:0}.toggle-slider:before{content:"";background:var(--text-dim);border-radius:50%;width:14px;height:14px;transition:transform .2s,background .2s;position:absolute;bottom:2px;left:2px}.toggle-switch input:checked+.toggle-slider{background:var(--accent-dim);border-color:var(--accent)}.toggle-switch input:checked+.toggle-slider:before{background:var(--accent);transform:translate(16px)}.panel-toggle{top:50%;right:calc(var(--space-md) + 22px);z-index:1;position:absolute;transform:translateY(-50%)}.panel-toggle-icon{top:50%;right:calc(var(--space-md) + 22px + 36px + 6px);color:var(--text-dim);pointer-events:none;z-index:1;display:inline-flex;position:absolute;transform:translateY(-50%)}.panel-toggle-icon[title]{pointer-events:auto}.panel-toggle-icon svg{display:block}.panel-header--no-connection .panel-toggle,.panel-header--no-connection .panel-toggle-icon{opacity:.4;transition:opacity .18s}.toggle-switch--bypass .toggle-slider{background:#c0392b73;border-color:#c0392b}.toggle-switch--bypass .toggle-slider:before{background:#e74c3c}.toggle-switch--bypass input:checked+.toggle-slider{background:#27ae6073;border-color:#27ae60}.toggle-switch--bypass input:checked+.toggle-slider:before{background:#2ecc71}.panel-header:has(.panel-toggle) .panel-title{padding-right:100px}.faff-overlay{z-index:9999;color:#f3e9d2;text-align:center;pointer-events:none;background:radial-gradient(circle,#1a2540 0%,#0a0f1d 75%);flex-direction:column;justify-content:center;align-items:center;gap:2rem;padding:2rem;font-family:ui-serif,Georgia,Times New Roman,serif;display:flex;position:fixed;inset:0}.faff-overlay__logo{filter:drop-shadow(0 6px 24px #00000080);opacity:.92;border-radius:24px;width:160px;height:160px}.faff-overlay__message{letter-spacing:.02em;opacity:.92;max-width:min(80vw,720px);font-size:clamp(1.25rem,2.5vw,2rem);font-style:italic;line-height:1.4}.faff-overlay__connect{background:#ffffff0a;border:1px solid #ffffff1f;border-radius:10px;flex-direction:column;align-items:center;gap:8px;max-width:min(90vw,280px);margin-top:clamp(16px,3vh,32px);padding:16px 20px;display:flex}.faff-overlay__connect-label{opacity:.85;letter-spacing:.04em;font-size:.95rem;font-weight:600}.faff-overlay__qr{border-radius:4px;width:160px;height:160px;display:block}.faff-overlay__url{font-family:var(--font-mono,ui-monospace, monospace);word-break:break-all;text-align:center;opacity:.75;max-width:240px;font-size:.78rem}.toggle-switch--warning input:checked+.toggle-slider{background:#f9731640;border-color:#f97316}.toggle-switch--warning input:checked+.toggle-slider:before{background:#f97316}.map-section-label{letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);padding-bottom:var(--space-xs);border-bottom:1px solid var(--border);font-size:.65rem;font-weight:600}.map-section-label--gap{margin-top:var(--space-xs)}.fog-row{align-items:center;gap:var(--space-xs);margin-bottom:6px;display:flex}.fog-row-label{color:var(--text-dim);font-size:.78rem;font-family:var(--font-mono);flex:none;width:90px}.fog-row--kind>.fog-row-label{width:auto}.fog-row--kind>.bg-fx-btn{flex:0 0 28px}.fog-row-select{flex:auto;min-width:0}.fog-mode-toggle{flex:auto;gap:4px;display:flex}.fog-mode-btn{border-width:1.5px;border-color:var(--border);color:var(--text);background:0 0;flex:50%}.fog-mode-btn:hover{background:#ffffff0a}.fog-mode-btn.is-active{border-color:var(--accent,#6aa3ff);background:var(--accent,#6aa3ff);color:#fff;font-weight:600}.btn--block{text-align:center;width:100%;display:block}.fog-row--actions{gap:6px;margin:8px 0;display:flex}.fog-action{border-width:1.5px;flex:50%;font-weight:600}.fog-action--paint{border-color:var(--ok);color:var(--ok);background:0 0}.fog-action--paint:hover{background:#22c55e1f}.fog-action--paint.is-active{background:var(--ok);color:#fff}.fog-action--erase{border-color:var(--danger);color:var(--danger);background:0 0}.fog-action--erase:hover{background:#e03e3e1f}.fog-action--erase.is-active{background:var(--danger);color:#fff}.fog-hint{color:var(--text-dim);font-size:.7rem;line-height:1.4}.fog-brush-controls{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-elevated);flex-direction:column;gap:6px;margin-top:6px;padding:8px;display:flex}.fog-brush-row{align-items:center;gap:8px;font-size:.8rem;display:flex}.fog-brush-row>span{color:var(--text-dim);flex:0 0 5.5em}.fog-brush-row>select,.fog-brush-row>input{flex:auto;min-width:0}.fog-brush-row--toggle{gap:8px}.fog-brush-row--toggle>.toggle-switch{flex:none;margin-right:auto}#fog-canvas.fog-brush{pointer-events:auto;cursor:crosshair}.fog-fill-controls{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-elevated);flex-direction:column;gap:6px;margin-top:6px;padding:8px;display:flex}#fog-canvas.fog-fill{pointer-events:auto;cursor:cell}.fog-shader-params{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-elevated);flex-direction:column;gap:6px;margin-top:6px;padding:8px;display:flex}.fog-shader-params-header{text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);margin-bottom:2px;font-size:.7rem}.fog-brush-modes{gap:4px;display:flex}.fog-brush-paint,.fog-brush-erase{border-width:1.5px;flex:50%;font-weight:600}.fog-brush-paint{border-color:var(--ok);color:var(--ok);background:0 0}.fog-brush-paint:hover{background:#22c55e1f}.fog-brush-paint.is-active{background:var(--ok);color:#fff}.fog-brush-erase{border-color:var(--danger);color:var(--danger);background:0 0}.fog-brush-erase:hover{background:#e03e3e1f}.fog-brush-erase.is-active{background:var(--danger);color:#fff}.fog-divider{border:none;border-top:1px solid var(--border);margin:8px 0}.mapfx-toolbar{gap:var(--space-xs);flex-wrap:wrap;align-items:center;display:flex}.mapfx-label{color:var(--text-dim);font-size:.78rem;font-family:var(--font-mono);padding-right:4px}.mapfx-kind-label{min-width:0;color:var(--text);white-space:nowrap;text-overflow:ellipsis;flex:auto;padding-right:4px;font-size:.85rem;overflow:hidden}.fx-popover-kind-select{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);margin-bottom:6px;padding:4px 8px;font-size:.85rem}#fog-canvas.mapfx-paint,#fog-canvas.mapfx-poly{pointer-events:auto;cursor:crosshair}.mapfx-selector{pointer-events:auto;cursor:pointer;opacity:.5;background:#141824d9;border:1.5px solid #ffffff8c;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;padding:0;transition:opacity .12s,transform 80ms;display:flex;position:absolute;transform:translate(-50%,-50%);box-shadow:0 2px 4px #0009}.mapfx-selector:hover{opacity:.85}.mapfx-selector svg{display:block}.mapfx-selector--selected{opacity:1;border-color:var(--accent,#6aa3ff);box-shadow:0 0 0 2px var(--accent,#6aa3ff), 0 2px 4px #0009}.mapfx-selector__delete{top:calc(100% - 6px);left:-6px;transform:translate(-50%,-50%)}.view-hint{color:var(--text-dim);margin-bottom:var(--space-sm);font-size:.7rem;line-height:1.4}.view-hint--editing{color:#ff8c00cc}.view-hint--gap{margin-top:var(--space-md)}.view-warn{color:#ffb86b;border-radius:var(--radius-sm);margin:0 0 var(--space-sm);background:#ff8c001a;border:1px solid #ff8c0066;padding:6px 8px;font-size:.75rem;line-height:1.4}.btn--warn{border-color:var(--warn);color:var(--warn);background:#d090202e}.btn--warn:hover{background:#d0902047}.viewport-actions{gap:var(--space-sm);flex-direction:column;display:flex}.btn--full{width:100%}.msglog{display:inline-flex}.msglog__btn{border-radius:var(--radius-md);width:24px;height:24px;color:var(--text-dim);cursor:pointer;opacity:.6;background:0 0;border:1px solid #0000;justify-content:center;align-items:center;padding:0;transition:opacity .15s,color .15s,background .15s;display:inline-flex;position:relative}.msglog__btn:hover{opacity:1;color:var(--text-secondary);background:#ffffff0f}.msglog__btn[aria-expanded=true]{opacity:1;color:var(--text-secondary);background:#ffffff14}.msglog__btn--blink{animation:1.4s ease-out msglog-twinkle}@keyframes msglog-twinkle{0%{color:var(--accent,#0d9adb);transform:scale(1)}20%{color:var(--accent,#0d9adb);transform:scale(1.25)}to{color:var(--text-dim);transform:scale(1)}}.msglog__dot{background:var(--accent,#0d9adb);width:7px;height:7px;color:var(--accent,#0d9adb);border-radius:50%;position:absolute;top:1px;right:1px;box-shadow:0 0 5px 1px}.msglog__dot[data-level=ok]{background:var(--ok);color:var(--ok)}.msglog__dot[data-level=warn]{background:var(--warn);color:var(--warn)}.msglog__dot[data-level=error]{background:var(--danger);color:var(--danger)}.msglog__pop{z-index:200;border:1px solid var(--border);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0a0e1af5;flex-direction:column;width:min(320px,100vw - 24px);max-height:50vh;display:flex;position:fixed;overflow:hidden;box-shadow:0 8px 28px #00000080}.msglog__head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:6px 8px 6px 10px;display:flex}.msglog__title{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim);font-size:.7rem}.msglog__copy{border-radius:var(--radius-sm);width:24px;height:24px;color:var(--text-dim);cursor:pointer;background:0 0;border:1px solid #0000;justify-content:center;align-items:center;padding:0;display:inline-flex}.msglog__copy:hover{color:var(--text-secondary);background:#ffffff0f}.msglog__copy--done{color:var(--ok)}.msglog__list{margin:0;padding:4px 0;list-style:none;overflow-y:auto}.msglog__item{font-size:var(--font-size-sm);color:var(--text-secondary);gap:8px;padding:4px 10px;line-height:1.35;display:flex}.msglog__item[data-level=warn]{color:var(--warn)}.msglog__item[data-level=error]{color:var(--danger)}.msglog__time{font-family:var(--font-mono);color:var(--text-dim);flex:none;padding-top:1px;font-size:.68rem}.msglog__text{word-break:break-word;flex:auto}.msglog__empty{text-align:center;font-size:var(--font-size-sm);color:var(--text-dim);padding:10px}.status-bar{padding:var(--space-sm) var(--space-md);font-family:var(--font-mono);font-size:var(--font-size-sm);color:var(--text-dim);border-top:1px solid var(--border);background:var(--bg-base);min-height:32px;margin-top:auto}.status-bar[data-level=error]{color:var(--danger)}.status-bar[data-level=warn]{color:var(--warn)}.status-bar[data-level=ok]{color:var(--ok)}.app-version{font-family:var(--font-mono);color:var(--text-dim);letter-spacing:.05em;opacity:.5;font-size:.65rem}.app-footer-row{padding:4px var(--space-md) 6px;justify-content:space-between;align-items:center;gap:var(--space-sm);display:flex}.storage-gauge{font-family:var(--font-mono);color:var(--text-dim);letter-spacing:.05em;opacity:.5;cursor:help;font-size:.65rem}.storage-gauge--warn{color:var(--warn);opacity:.85}#gm-markers-canvas{pointer-events:auto;z-index:1}.context-menu{z-index:20;background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-xs);min-width:150px;position:absolute;box-shadow:0 4px 12px #00000080}.context-menu button{width:100%;padding:var(--space-xs) var(--space-sm);color:var(--text-primary);font-size:var(--font-size-sm);text-align:left;cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;display:block}.context-menu button:hover{background:var(--bg-hover)}.context-menu button:disabled{color:var(--text-dim);cursor:not-allowed;opacity:.6}.context-menu button:disabled:hover{background:0 0}.marker-text-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--font-size-sm);padding:var(--space-xs) var(--space-sm);outline:none;grid-column:2/span 2;width:100%}.marker-text-input:focus{border-color:var(--border-focus)}.marker-icon-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:48px;color:var(--text-primary);text-align:center;padding:var(--space-xs);outline:none;font-size:1rem}.marker-icon-input:focus{border-color:var(--border-focus)}.marker-icon-btn{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;width:36px;height:28px;color:var(--text-primary);justify-content:center;align-items:center;padding:0;font-size:1rem;display:inline-flex}.marker-icon-btn:hover{border-color:var(--border-focus)}.marker-icon-btn img{object-fit:contain;width:20px;height:20px}.marker-icon-block{align-items:stretch;gap:var(--space-md);margin-bottom:var(--space-sm);display:flex}.marker-icon-labels{justify-content:center;gap:var(--space-sm);flex-direction:column;flex:1;display:flex}.marker-icon-label-row{justify-content:space-between;align-items:center;gap:var(--space-sm);display:flex}.marker-icon-label-row[hidden]{display:none}.marker-icon-btn--lg{flex-shrink:0;width:64px;height:64px;font-size:2rem}.marker-icon-btn--lg img{width:48px;height:48px}.marker-role-btns{gap:4px;margin-bottom:6px;display:flex}.marker-role-btn{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;white-space:nowrap;flex:1;padding:4px;font-size:11px;transition:border-color .15s,color .15s,background .15s}.marker-role-btn:hover{border-color:var(--border-focus);color:var(--text-primary)}.marker-role-btn--active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.marker-role-btn--listener{color:#48d1ccb3;border-color:#48d1cc4d}.marker-role-btn--listener:hover{color:#48d1cc;border-color:#48d1cc}.marker-role-btn--listener.marker-role-btn--active{color:#48d1cc;background:#48d1cc1a;border-color:#48d1cc}.marker-role-btn--tracker{color:#f59e0bb3;border-color:#f59e0b4d}.marker-role-btn--tracker:hover{color:#f59e0b;border-color:#f59e0b}.marker-role-btn--tracker.marker-role-btn--active{color:#f59e0b;background:#f59e0b1a;border-color:#f59e0b}.marker-sound-row{align-items:center}.marker-sound-row .btn{margin-left:auto}.marker-playback-row{align-items:center}.marker-mode-btns{gap:4px;margin-left:auto;display:flex}.marker-mode-btns .btn{justify-content:center;align-items:center;padding:3px 6px;line-height:1;display:flex}.panel-sep{background:var(--border);height:1px;margin:var(--space-sm) 0;border:0}.sb-mute-row{margin-bottom:2px}.sb-remote-row{margin-bottom:var(--space-sm)}.sb-slot{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:var(--space-xs);overflow:hidden}.sb-slot-empty{gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);align-items:center;display:flex}.sb-slot-empty .sb-assign-btn{flex:1}.sb-slot-name-row{align-items:center;gap:var(--space-xs);padding:5px var(--space-sm) 2px;display:flex}.sb-name-btn{color:var(--text-primary);font-size:var(--font-size-sm);cursor:pointer;text-align:left;white-space:nowrap;text-overflow:ellipsis;border-radius:var(--radius-sm);background:0 0;border:none;flex:1;padding:2px 4px;font-weight:500;overflow:hidden}.sb-name-btn:hover{background:var(--bg-hover)}.sb-slot-controls{align-items:center;gap:var(--space-xs);padding:2px var(--space-sm) 5px;display:flex}.sb-play-btn{flex-shrink:0;min-width:32px}.sb-mode-btns{border:1px solid var(--border);border-radius:4px;flex-shrink:0;display:flex;overflow:hidden}.sb-mode-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:3px 6px;line-height:1;transition:background .1s,color .1s;display:flex}.sb-mode-btn:hover{background:var(--surface-2);color:var(--text)}.sb-mode-btn--active{background:var(--accent);color:#fff}.sb-mode-btn--active:hover{background:var(--accent)}.sb-random-row{align-items:center;gap:var(--space-xs);padding:0 var(--space-sm) 4px;display:flex}.sb-random-freq{min-width:0;height:16px;accent-color:var(--accent);flex:1}.sb-random-label{color:var(--text-muted);white-space:nowrap;text-align:right;min-width:60px;font-size:.6rem}.sb-volume{min-width:0;height:18px;accent-color:var(--accent);flex:1}.sb-remove-btn{flex-shrink:0}.sb-loading{opacity:.5;cursor:not-allowed}.sb-progress-track{background:var(--bg-base);height:3px}.sb-progress-fill{background:var(--accent);width:0%;height:100%;transition:width 50ms linear}.sb-pagination{justify-content:center;align-items:center;gap:var(--space-sm);margin:var(--space-xs) 0;font-size:var(--font-size-sm);color:var(--text-secondary);display:flex}.sb-attr-btn{margin-top:var(--space-xs);opacity:.6}.sb-attr-btn:hover{opacity:1}.modal-overlay{z-index:1000;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-dialog{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;width:560px;max-width:95vw;max-height:85vh;display:flex;overflow:hidden}.modal-dialog--sm{width:480px}.img-modal-dialog{width:920px;max-width:95vw;height:720px;max-height:90vh}.img-modal-store-tag{margin-left:var(--space-sm);cursor:help}.img-modal-body{flex:1;min-height:0;display:flex}.img-modal-sidebar{border-right:1px solid var(--border);width:220px;padding:var(--space-md) 0;background:var(--bg-deep,#00000026);flex-direction:column;flex-shrink:0;gap:2px;display:flex;overflow-y:auto}.img-modal-sidebar-section{padding:var(--space-sm) var(--space-md) 4px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);font-size:.72rem}.img-modal-sidebar-cat{padding:6px var(--space-md);color:var(--text);cursor:pointer;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;width:100%;font-size:.92rem;display:flex}.img-modal-sidebar-cat:hover{background:var(--accent-dim)}.img-modal-sidebar-cat.is-active{background:var(--accent-dim);color:var(--accent-hover);font-weight:600}.img-cat-count{color:var(--text-dim);background:#ffffff0f;border-radius:999px;padding:1px 6px;font-size:.78rem}.img-modal-sidebar-cat.is-active .img-cat-count{color:var(--text)}.img-modal-sidebar-add{margin:var(--space-sm) var(--space-md);border:1px dashed var(--border);color:var(--text-dim);cursor:pointer;background:0 0;border-radius:4px;padding:6px;font-size:.88rem}.img-modal-sidebar-add:hover{color:var(--accent);border-color:var(--accent-dim)}.img-modal-main{flex-direction:column;flex:1;min-width:0;display:flex}.img-modal-toolbar{align-items:center;gap:var(--space-sm);padding:var(--space-md);border-bottom:1px solid var(--border);flex-wrap:wrap;display:flex}.img-modal-cat-title{margin-right:auto;font-size:.95rem;font-weight:600}.img-modal-search{background:var(--bg-deep,#0003);border:1px solid var(--border);width:220px;color:var(--text);border-radius:4px;padding:4px 8px;font-size:.9rem}.img-modal-search:focus{outline:1px solid var(--accent)}.img-modal-grid{padding:var(--space-md);gap:var(--space-sm);flex:1;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));align-content:start;display:grid;overflow-y:auto}.img-modal-empty{color:var(--text-dim);text-align:center;padding:var(--space-lg);grid-column:1/-1;font-size:.92rem}.img-modal-cell{border:1px solid var(--border);background:#ffffff05;border-radius:6px;flex-direction:column;align-items:center;min-height:100px;padding:8px 4px;transition:border-color .12s,background .12s;display:flex;position:relative}.img-modal-cell:hover{border-color:var(--accent-dim);background:#ffffff0d}.img-modal-cell[draggable=true]{cursor:grab}.img-modal-cell[draggable=true]:active{cursor:grabbing}.img-modal-cell.is-dragging{opacity:.35}.img-modal-cell--pickable{cursor:pointer}.img-modal-cell--pickable:hover{border-color:var(--accent);background:var(--accent-dim)}.img-modal-sidebar-cat.is-drop-target{background:var(--accent-dim);border:1px dashed var(--accent);color:var(--accent-hover)}.img-modal-visual{width:64px;height:64px;color:var(--text);justify-content:center;align-items:center;display:flex}.img-modal-unicode{font-size:40px;line-height:1}.img-modal-svg{width:64px;height:64px}.img-modal-img{object-fit:contain;max-width:64px;max-height:64px}.img-modal-broken{color:var(--text-dim);font-size:28px}.img-modal-label{color:var(--text-dim);text-align:center;white-space:nowrap;text-overflow:ellipsis;max-width:100%;margin-top:4px;font-size:.74rem;overflow:hidden}.img-modal-del{width:18px;height:18px;color:var(--text);text-align:center;cursor:pointer;opacity:0;background:#0006;border:none;border-radius:50%;padding:0;font-size:14px;line-height:18px;transition:opacity .12s;position:absolute;top:2px;right:2px}.img-modal-cell:hover .img-modal-del{opacity:1}.img-modal-del:hover{background:var(--danger,#c0392b)}.img-modal-edit{width:18px;height:18px;color:var(--text);text-align:center;cursor:pointer;opacity:0;background:#0006;border:none;border-radius:50%;padding:0;font-size:11px;line-height:18px;transition:opacity .12s;position:absolute;top:2px;right:24px}.img-modal-cell:hover .img-modal-edit{opacity:1}.img-modal-edit:hover{background:var(--accent,#6aa3ff);color:#fff}.img-modal-preview-popover{z-index:1100;pointer-events:none;background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--space-md);max-width:280px;position:fixed;box-shadow:0 4px 16px #0009}.img-modal-preview-visual{width:192px;height:192px;color:var(--text);margin:0 auto var(--space-sm);justify-content:center;align-items:center;display:flex}.img-modal-preview-visual .img-modal-unicode{font-size:128px}.img-modal-preview-visual .img-modal-svg{width:192px;height:192px}.img-modal-preview-visual .img-modal-img{max-width:192px;max-height:192px}.img-modal-preview-label{text-align:center;margin-bottom:2px;font-size:.95rem;font-weight:600}.img-modal-preview-meta{color:var(--text-dim);text-align:center;font-size:.8rem;line-height:1.3}.img-modal-tabs{padding:var(--space-sm) var(--space-md) 0;border-bottom:1px solid var(--border);gap:2px;display:flex}.img-modal-tab{color:var(--text-dim);cursor:pointer;background:0 0;border:1px solid #0000;border-bottom:none;border-radius:4px 4px 0 0;margin-bottom:-1px;padding:6px 12px;font-size:.88rem}.img-modal-tab:hover{color:var(--text)}.img-modal-tab.is-active{background:var(--bg-panel);border-color:var(--border);color:var(--text)}.img-modal-license-chip{border:1px solid var(--border);color:var(--text-dim);white-space:nowrap;border-radius:3px;padding:2px 6px;font-size:.72rem;text-decoration:none}.img-modal-license-chip:hover{color:var(--accent);border-color:var(--accent-dim)}.img-modal-import-target{color:var(--text-dim);white-space:nowrap;margin-left:auto;font-size:.78rem}.img-modal-target-select{background:var(--bg-panel);border:1px solid var(--border);color:var(--text);border-radius:3px;padding:3px 6px;font-family:inherit;font-size:.82rem}.img-modal-target-select:focus{outline:1px solid var(--accent)}.img-modal-target-select option{background:var(--bg-panel);color:var(--text)}.img-modal-more{justify-content:space-between;align-items:center;gap:var(--space-md);padding:var(--space-md);border-top:1px dashed var(--border);margin-top:var(--space-sm);display:flex}.img-modal-more-status{color:var(--text-dim);font-size:.85rem}.img-modal-font-row{padding:var(--space-md);border:1px solid var(--border);background:#ffffff05;border-radius:4px;flex-direction:column;grid-column:1/-1;gap:4px;display:flex;position:relative}.img-modal-font-name{color:var(--text);font-size:.95rem;font-weight:600}.img-modal-font-sample{color:var(--text);margin:2px 0;font-size:1.6rem;line-height:1.25}.img-modal-font-meta{color:var(--text-dim);font-size:.82rem}.img-modal-font-vibe{font-style:italic}.img-modal-font-attrib{margin-top:2px;font-size:.78rem}.img-modal-font-actions{gap:4px;display:flex;position:absolute;top:6px;right:6px}.img-modal-font-action{border:1px solid var(--border);width:22px;height:22px;color:var(--text-dim);cursor:pointer;background:#00000040;border-radius:4px;justify-content:center;align-items:center;padding:0;font-size:14px;line-height:1;display:inline-flex}.img-modal-font-action:hover{color:var(--text);border-color:var(--accent-dim)}.img-modal-font-action--danger:hover{color:#fff;background:var(--danger,#c0392b);border-color:var(--danger,#c0392b)}.txt-map-dialog{width:96vw;height:94vh}.txt-map-dialog--canvas{flex-direction:column;display:flex}.txt-map-toolbar{gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border);background:var(--bg-panel);flex-shrink:0;align-items:stretch;display:flex}.txt-map-toolbar-left,.txt-map-toolbar-right{align-items:stretch;gap:var(--space-sm);flex-wrap:wrap;flex:none;display:flex}.txt-map-toolbar-col{gap:var(--space-sm);flex-direction:column;align-items:stretch;display:flex}.txt-map-toolbar-centre{align-items:stretch;gap:var(--space-sm);flex-wrap:wrap;flex:auto;justify-content:center;min-width:0;display:flex}.txt-map-toolbar-section{flex-direction:column;justify-content:flex-start;gap:4px;display:flex}.txt-map-toolbar-section[hidden]{display:none}.txt-map-toolbar-section-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:600}.txt-map-toolbar-section-row{align-items:center;gap:var(--space-sm);flex-wrap:wrap;min-height:28px;display:flex}.txt-map-toolbar-divider{background:var(--border);flex-shrink:0;align-self:stretch;width:1px}.txt-map-toolbar-name{width:220px;min-width:120px}.txt-map-animation-name{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;min-width:100px;max-width:180px;font-size:.88rem;overflow:hidden}.txt-map-toolbar-group-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:600}.reveal-progress{background:#ffffff14;border-radius:3px;height:6px;margin-top:4px;overflow:hidden}.reveal-progress[hidden]{display:none}.reveal-progress-bar{background:var(--accent,#6aa3ff);width:100%;height:100%;transition:width 1s linear}.txt-map-toolbar-clipboard{align-items:center;gap:2px;display:inline-flex}.txt-map-icon-btn{justify-content:center;align-items:center;width:28px;height:26px;padding:0;display:inline-flex}.txt-map-toolbar-sep{background:var(--border);width:1px;height:22px;margin:0 var(--space-sm);display:inline-block}.txt-map-toolbar-checkbox{color:var(--text-secondary);-webkit-user-select:none;user-select:none;cursor:pointer;align-items:center;gap:4px;font-size:.85rem;display:inline-flex}.txt-map-toolbar-checkbox input{margin:0}.txt-map-canvas-wrap{padding:var(--space-md);background:#0000004d;flex:1;place-items:center;min-height:0;display:grid;overflow:hidden}.txt-map-el{box-sizing:border-box;border:1px dashed #0000;position:absolute}.txt-map-el-body{box-sizing:border-box;cursor:text;outline:none;width:100%;height:100%;padding:.4em .6em;overflow:hidden}.txt-map-el-body p{margin:0}.txt-map-el-body ul,.txt-map-el-body ol{margin:0 0 .6em;padding-left:1.6em}.txt-map-el-body li{margin:0}.txt-map-el-body--text:empty:before{content:attr(data-placeholder);color:var(--text-dim);opacity:.7;pointer-events:none;font-style:italic}.txt-map-el--image .txt-map-el-body{cursor:grab;padding:0;display:block}.txt-map-el-body--video{cursor:grab;background:#000;padding:0;display:block;overflow:hidden}.txt-map-el-video-frame{pointer-events:none;border:0;width:100%;height:100%;display:block}.txt-map-el--selected .txt-map-el-video-frame{pointer-events:auto}.txt-map-el--image .txt-map-el-body>span,.txt-map-el--image .txt-map-el-body>svg,.txt-map-el--image .txt-map-el-body>img{width:100%!important;height:100%!important;display:block!important}.txt-map-el--image .txt-map-el-body>img{object-fit:contain}.txt-map-el--image.txt-map-el--unlocked .txt-map-el-body>img{object-fit:fill}.txt-map-el--image .txt-map-el-body>span>svg{width:100%!important;height:100%!important;display:block!important}.txt-map-el--selected{outline:1px dashed var(--accent,#6aa3ff);outline-offset:1px;z-index:10;box-shadow:inset 0 0 0 9999px #ffffff0a}.txt-map-el-drag,.txt-map-el-resize,.txt-map-el-delete{color:#fffffff2;z-index:2;cursor:pointer;-webkit-user-select:none;user-select:none;pointer-events:auto;touch-action:none;background:#141824d9;border:1.5px solid #ffffff8c;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;padding:0;transition:background .12s,color .12s,transform 80ms;display:none;position:absolute;box-shadow:0 2px 4px #0009}.txt-map-el-drag svg,.txt-map-el-resize svg,.txt-map-el-delete svg{display:block}.txt-map-el--selected .txt-map-el-drag,.txt-map-el--selected .txt-map-el-resize,.txt-map-el--selected .txt-map-el-delete{display:flex}.txt-map-el-drag:hover,.txt-map-el-resize:hover{color:var(--accent,#fff);background:#283246f2;border-color:#ffffffd9}.txt-map-el-drag:active,.txt-map-el-resize:active,.txt-map-el-delete:active{transform:scale(.94)}.txt-map-el-drag{cursor:move;top:-11px;left:-11px}.txt-map-el-resize{cursor:nwse-resize;border-width:2px;border-color:#5af07ad9;border-radius:5px;bottom:-11px;right:-11px}.txt-map-el-delete{color:#ffc4c4;border-color:#dc5050d9;bottom:-11px;left:-11px}.txt-map-el-delete:hover{color:#fff;background:#b42828f2;border-color:#ff8080}.txt-map-el-rotate-handle,.txt-map-el-flip{color:#fffffff2;cursor:pointer;-webkit-user-select:none;user-select:none;pointer-events:auto;touch-action:none;z-index:3;background:#141824d9;border:1.5px solid #ffffff8c;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;padding:0;display:none;position:absolute;box-shadow:0 2px 4px #0009}.txt-map-el-rotate-handle{border:2px solid #5af07ad9;top:-42px;left:50%;transform:translate(-50%)}.txt-map-el-rotate-stem{pointer-events:none;z-index:2;border-left:1.5px dashed #5af07ad9;width:0;height:28px;display:none;position:absolute;top:-28px;left:50%}.txt-map-el-flip--v{top:-11px;left:50%;transform:translate(-50%)}.txt-map-el-flip--h{top:50%;right:-11px;transform:translateY(-50%)}.txt-map-el-flip.is-active{color:#0a0e1a;background:#5af07ad9;border-color:#fff}.txt-map-el-rotate-handle:hover,.txt-map-el-flip:hover{filter:brightness(1.2)}.txt-map-el-lock,.txt-map-el-reset{color:#fffffff2;cursor:pointer;z-index:3;background:#141824d9;border:1.5px solid #ffffff8c;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;padding:0;display:none;position:absolute;right:-11px;box-shadow:0 2px 4px #0009}.txt-map-el-lock{bottom:19px}.txt-map-el-reset{bottom:49px}.txt-map-el-lock:hover,.txt-map-el-reset:hover{filter:brightness(1.2)}.txt-map-el-lock.is-active{color:#0a0e1a;background:#5af07ad9;border-color:#fff}.txt-map-el--selected .txt-map-el-rotate-handle,.txt-map-el--selected .txt-map-el-flip,.txt-map-el--selected .txt-map-el-rotate-stem,.txt-map-el--selected .txt-map-el-lock,.txt-map-el--selected .txt-map-el-reset{display:flex}.txt-map-toolbar-element{align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.txt-map-toolbar-element[hidden]{display:none}.txt-map-element-toolbar-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;margin-left:var(--space-sm);font-size:.78rem}.txt-map-element-toolbar-label:first-child{margin-left:0}.txt-map-element-slider{width:120px}.txt-map-element-slider-val{color:var(--text-dim);text-align:right;min-width:32px;font-size:.85rem;display:inline-block}.txt-map-element-hint{color:var(--text-dim);font-size:.82rem;font-style:italic}.txt-map-align-group{gap:2px;display:inline-flex}.txt-map-align-group .btn--active{background:var(--accent,#6aa3ff);color:#fff;border-color:var(--accent,#6aa3ff)}.txt-map-body{gap:var(--space-md);min-height:0;padding:var(--space-md);flex:1;display:flex}.txt-map-controls{gap:var(--space-sm);width:360px;padding-right:var(--space-sm);flex-direction:column;flex-shrink:0;display:flex;overflow-y:auto}.txt-map-field{flex-direction:column;gap:4px;display:flex}.txt-map-field-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;font-size:.78rem}.txt-map-input{background:var(--bg-panel);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:6px 8px;font-family:inherit;font-size:.92rem}.txt-map-input:focus{outline:1px solid var(--accent)}.txt-map-textarea{background:var(--bg-panel);color:var(--text);border:1px solid var(--border);resize:vertical;border-radius:4px;min-height:140px;padding:8px;font-family:monospace;font-size:.85rem}.txt-map-textarea:focus{outline:1px solid var(--accent)}.txt-map-slider-row{align-items:center;gap:var(--space-sm);display:flex}.txt-map-slider-row input[type=range]{flex:1}.txt-map-slider-val{color:var(--text-dim);min-width:40px;font-size:.85rem}.txt-map-color{border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:4px;width:56px;height:30px;padding:0}.txt-map-alt-input{border:1px solid var(--border);background:var(--bg-input);min-width:140px;height:30px;color:var(--text-primary);font-size:var(--font-size-sm);border-radius:4px;padding:4px 8px}.txt-map-preview-wrap{border:1px solid var(--border);padding:var(--space-md);background:#00000040;border-radius:6px;flex:1;place-items:center;min-width:0;min-height:0;display:grid;overflow:hidden}.txt-map-preview{justify-content:center;align-items:center;display:flex}.txt-map-page{line-height:1.45;display:block;position:relative;overflow:hidden;box-shadow:0 4px 24px #00000080}.txt-map-page--transparent{background-color:#fff;background-image:linear-gradient(45deg,#ccc 25%,#0000 25% 75%,#ccc 75%,#ccc),linear-gradient(45deg,#ccc 25%,#0000 25% 75%,#ccc 75%,#ccc);background-position:0 0,10px 10px;background-size:20px 20px}.txt-map-page-content{box-sizing:border-box;width:100%;height:100%;padding:6%;overflow-y:auto}.txt-map-footer{padding:var(--space-md);border-top:1px solid var(--border);justify-content:flex-end;gap:var(--space-sm);display:flex}.img-modal-footer{padding:var(--space-sm) var(--space-md);border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:var(--space-sm);background:var(--bg-deep,#00000026);display:flex}.img-modal-token-link{text-decoration:none}.img-modal-cell--connector{min-height:108px;padding-bottom:6px}.img-modal-cell--connector .img-modal-visual{width:44px;height:44px}.img-modal-cell--connector .img-modal-unicode{font-size:28px}.img-modal-cell--connector .img-modal-svg{width:44px;height:44px}.img-modal-cell--connector .img-modal-img{max-width:44px;max-height:44px}.img-modal-cell--connector .img-modal-import{border:1px solid var(--accent-dim);width:100%;color:var(--accent);cursor:pointer;background:0 0;border-radius:3px;margin-top:6px;padding:3px 8px;font-family:inherit;font-size:.78rem;display:block}.img-modal-cell--connector .img-modal-import:hover{background:var(--accent-dim);color:var(--accent-hover)}.img-modal-cell--connector .img-modal-import:disabled{opacity:.6;cursor:default}.about-dialog{width:900px}.about-body{padding:var(--space-lg);flex:1;overflow-y:auto}.about-display,.about-edit{gap:var(--space-md);flex-direction:column;display:flex}.about-image{object-fit:cover;border-radius:var(--radius-md);width:100%;max-height:220px;display:block}.about-image-frame{aspect-ratio:16/6;border:1px solid var(--border);border-radius:var(--radius-md);cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;background:#0000004d;width:100%;position:relative;overflow:hidden}.about-image-frame--dragging{cursor:grabbing}.about-image-frame .about-image{pointer-events:none;border-radius:0;width:100%;height:100%;max-height:none}.about-image-hint{color:var(--text-dim);font-size:.72rem;font-style:italic}.rte{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-input);flex-direction:column;display:flex;overflow:hidden}.rte-toolbar{background:var(--bg-panel);border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:2px;padding:4px;display:flex}.rte-btn{min-width:28px;height:24px;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:1px solid #0000;padding:0 6px;font-size:.78rem;line-height:1}.rte-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border)}.rte-sep{background:var(--border);width:1px;height:18px;margin:0 4px}.rte-select{background:var(--bg-input);height:24px;color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:0 4px;font-size:.75rem}.rte-color{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:0 0;width:24px;height:24px;padding:0}.rte-editor{width:100%;min-height:140px;padding:var(--space-sm);background:var(--bg-input);color:var(--text-primary);font-family:inherit;font-size:var(--font-size-base);border:none;border-radius:0;outline:none;line-height:1.5;overflow-y:auto}.rte-editor:focus{border-color:#0000;outline:none}.rte-editor p{margin:0 0 .6em}.rte-editor p:last-child{margin-bottom:0}.rte-editor ul,.rte-editor ol{margin:0 0 .6em;padding-left:1.6em}.rte-editor li{margin:0 0 .2em}.rte-editor img,.rte-editor span[style*=inline-block]{cursor:pointer}.rte-editor img:hover,.rte-editor span[style*=inline-block]:hover{outline:1px solid var(--accent,#6aa3ff);outline-offset:1px}.rte-editor span[contenteditable=false],.txt-map-page span[contenteditable=false]{box-sizing:border-box;vertical-align:middle;background:0 0!important;overflow:hidden!important}.rte-editor span[contenteditable=false]>svg,.txt-map-page span[contenteditable=false]>svg{pointer-events:none;max-width:100%;max-height:100%;display:block;background:0 0!important;width:100%!important;height:100%!important}.rte-editor:empty:before{content:attr(data-placeholder);color:var(--text-dim);pointer-events:none;font-style:italic}.about-theme{gap:var(--space-sm);padding:var(--space-sm);border:1px solid var(--border);border-radius:var(--radius-md);background:#ffffff05;flex-direction:column;display:flex}.about-theme-heading{font-size:var(--font-size-sm);color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.about-theme-row{align-items:center;gap:var(--space-sm);grid-template-columns:80px 1fr;display:grid}.about-theme-row-label{color:var(--text-secondary);font-size:var(--font-size-sm)}.about-seg{border:1px solid var(--border);border-radius:var(--radius-md);align-self:start;display:inline-flex;overflow:hidden}.about-seg-btn{color:var(--text-secondary);font-size:var(--font-size-sm);cursor:pointer;background:0 0;border:0;padding:4px 14px;transition:background .15s,color .15s}.about-seg-btn:hover:not(.about-seg-btn--active){background:var(--bg-hover);color:var(--text-primary)}.about-seg-btn--active{background:var(--accent);color:#fff}.about-accent{align-items:center;gap:var(--space-sm);display:flex}.about-accent-swatch{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:0 0;width:32px;height:28px;padding:0}.about-accent-hex{font-family:var(--font-mono);color:var(--text-secondary);font-size:.78rem}.settings-body{min-height:0;max-height:75vh;padding:var(--space-md);gap:var(--space-md);scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex-direction:column;flex:1;display:flex;overflow-y:auto}.settings-body::-webkit-scrollbar{width:10px}.settings-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:5px}.settings-body::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.settings-section{border:1px solid var(--border);border-radius:var(--radius-md);background:#ffffff05;padding:0;overflow:visible}.settings-section>.settings-section-title{cursor:pointer;padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm);color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;-webkit-user-select:none;user-select:none;background:#1e3a5f33;font-weight:600;list-style:none;transition:background .12s,color .12s;position:relative}.settings-section>.settings-section-title::-webkit-details-marker{display:none}.settings-section>.settings-section-title:after{content:"▸";right:var(--space-md);font-size:.65rem;transition:transform .18s;position:absolute;top:50%;transform:translateY(-50%)}.settings-section[open]>.settings-section-title:after{transform:translateY(-50%)rotate(90deg)}.settings-section>.settings-section-title:hover{color:var(--text-primary);background:#1e3a5f59}.settings-section[open]{gap:var(--space-sm);flex-direction:column;display:flex}.settings-section[open]>:not(.settings-section-title){padding-left:var(--space-md);padding-right:var(--space-md)}.settings-section[open]>.settings-section-intro{padding-top:var(--space-sm)}.settings-section[open]>:last-child:not(.settings-section-title){padding-bottom:var(--space-md)}.settings-section-heading{font-size:var(--font-size-sm);color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.settings-section-intro{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0;line-height:1.5}.settings-stat{color:var(--text-primary);font-size:var(--font-size-base)}.settings-stat-sub{color:var(--text-secondary);font-size:var(--font-size-sm)}.settings-btn-row{gap:var(--space-sm);display:flex}.settings-stagecraft-wled-list{flex-direction:column;gap:4px;display:flex}.settings-stagecraft-wled-row{padding:6px var(--space-sm);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.settings-stagecraft-wled-add,.settings-stagecraft-ha-form{flex-wrap:wrap;gap:6px;display:flex}.settings-stagecraft-wled-add input,.settings-stagecraft-ha-form input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font:inherit;flex:140px;padding:4px 6px}.settings-stagecraft-ha{margin-top:10px}#stagecraft-assignments{flex-direction:column;gap:6px;display:flex}.stagecraft-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.stagecraft-row label{font-size:var(--font-size-sm);color:var(--text-secondary);flex:none}.stagecraft-select{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font:inherit;flex:auto;padding:4px 6px}.stagecraft-config-link{font-size:var(--font-size-sm);color:var(--accent);border-radius:var(--radius-sm);flex:none;padding:4px 6px;text-decoration:none}.stagecraft-config-link:hover{background:var(--bg-input);text-decoration:underline}#soundtracks-slots{flex-direction:column;gap:10px;display:flex}.soundtrack-slot{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:4px;padding:6px;display:flex}.soundtrack-slot-header{justify-content:space-between;align-items:center;gap:6px;min-width:0;display:flex}.soundtrack-slot-header>.btn{flex:none}.soundtrack-slot-header>.soundtrack-slot-label-input,.soundtrack-slot-header>.soundtrack-slot-label{flex:auto;min-width:0}.soundtrack-slot-type{width:18px;height:18px;color:var(--text-secondary);flex:none;justify-content:center;align-items:center;display:inline-flex}.soundtrack-slot.is-active .soundtrack-slot-type{color:var(--accent)}.soundtrack-provider-badge{flex:none;justify-content:center;align-items:center;width:18px;height:18px;display:inline-flex}.soundtrack-slot-label{font-weight:600;font-size:var(--font-size-sm)}.soundtrack-tracks{flex-direction:column;gap:2px;display:flex}.soundtrack-track{font-size:var(--font-size-sm);color:var(--text-secondary);justify-content:space-between;align-items:center;gap:4px;padding:2px 4px;display:flex}.soundtrack-track.is-playing{color:var(--accent);font-weight:600}.soundtrack-add-row{gap:4px;margin-top:2px;display:flex}.soundtrack-add-row input{background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font:inherit;flex:auto;padding:3px 6px}.soundtrack-volume-row{align-items:center;gap:6px;margin-top:2px;display:flex}.soundtrack-volume-row input[type=range]{flex:auto}.settings-stat-sub.soundtrack-status--error{color:#ff8e6c;font-weight:500}.soundtrack-icon-toggle{width:28px;height:28px;color:var(--text-secondary);flex:none;justify-content:center;align-items:center;padding:0;display:inline-flex}.soundtrack-icon-toggle.is-active{color:var(--accent);background:#ffffff0f}.soundtrack-icon-toggle:hover:not(:disabled){color:var(--text-primary)}.soundtrack-play-btn{flex:none;justify-content:center;align-items:center;width:28px;height:28px;padding:0;display:inline-flex}.soundtrack-slot.is-active .soundtrack-play-btn{color:var(--accent)}.soundtrack-transport{align-items:center;gap:4px;margin-top:2px;display:flex}.soundtrack-transport .btn{justify-content:center;align-items:center;width:28px;height:28px;padding:0;display:inline-flex}.soundtrack-now-playing{font-size:var(--font-size-sm);color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;margin-top:2px;font-style:italic;overflow:hidden}.sb-progress-track.soundtrack-progress{margin-top:4px}.sb-progress-track.soundtrack-progress--clickable{cursor:pointer;height:5px;position:relative}.sb-progress-track.soundtrack-progress--clickable:hover{filter:brightness(1.2)}.soundtrack-progress-tick{pointer-events:none;width:2px;position:absolute;top:-2px;bottom:-2px}.soundtrack-progress-tick--start{background:#5af07a}.soundtrack-progress-tick--end{background:#ff8e6c}.soundtrack-slot.is-active{outline:2px solid var(--accent);outline-offset:-2px;background:color-mix(in srgb, var(--accent) 14%, var(--bg-input))}.soundtrack-slot.is-active .soundtrack-slot-label,.soundtrack-slot.is-active .soundtrack-slot-label-input{color:var(--accent);font-weight:600}.soundtrack-slot-label-input{background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font:inherit;flex:auto;padding:3px 6px;font-weight:600}.soundtrack-mode-row,.soundtrack-time-row,.soundtrack-shuffle-row{align-items:center;gap:6px;display:flex}.soundtrack-mode-row select{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font:inherit;flex:auto;padding:3px 6px}.soundtrack-time-row label,.soundtrack-time-cell{font-size:var(--font-size-sm);color:var(--text-secondary);align-items:center;gap:4px;display:flex}.soundtrack-time-grab{cursor:pointer;border-radius:var(--radius-sm);-webkit-user-select:none;user-select:none;padding:1px 4px}.soundtrack-time-grab:hover{background:var(--bg-base);color:var(--text-primary)}.soundtrack-time-row input[type=number]{background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);width:70px;color:var(--text-primary);font:inherit;padding:3px 6px}.settings-stagecraft-spotify-connect{margin-top:8px}.settings-stagecraft-spotify-connect code{background:var(--bg-base);border-radius:var(--radius-sm);padding:1px 4px;font-size:.95em}.settings-spotify-steps{margin:4px 0 6px;padding-left:20px}.settings-spotify-steps li{margin:2px 0}.settings-key-list{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.settings-key-list li{padding:6px var(--space-sm);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:var(--text-primary);justify-content:space-between;align-items:center;display:flex}.settings-key-preview{font-family:var(--font-mono);color:var(--text-secondary)}.settings-key-label{flex:auto;min-width:0}.settings-key-del{margin-left:var(--space-sm);flex:none}.settings-danger{border-color:#e03e3e66}.settings-danger-row{justify-content:space-between;align-items:center;gap:var(--space-md);padding:var(--space-sm) 0;border-top:1px solid var(--border);display:flex}.settings-danger-row:first-of-type{border-top:0}.settings-danger-row>:first-child{flex:auto;min-width:0}.settings-danger-row>:last-child{flex:none}.about-title{letter-spacing:.01em;color:var(--text-primary);margin:0;font-size:1.45rem;font-weight:600}.about-text{color:var(--text-secondary);margin:0;font-size:.95rem;line-height:1.6}.about-text p{margin:0 0 .85em}.about-text p:last-child{margin-bottom:0}.about-text ul,.about-text ol{margin:.2em 0 .95em;padding-left:1.5em}.about-text li{margin-bottom:.4em;padding-left:4px}.about-text li::marker{color:var(--accent)}.about-text li:last-child{margin-bottom:0}.about-text strong,.about-text b{color:var(--text-primary);font-weight:600}.about-text em,.about-text i{color:var(--text-primary);font-style:italic}.about-text code{font-family:var(--font-mono);background:var(--code-bg);color:var(--code-text);border-radius:var(--radius-sm);padding:1px 6px;font-size:.85em}.about-text a{color:var(--accent);text-decoration:none}.about-text a:hover{text-decoration:underline}.about-links-heading{font-size:var(--font-size-sm);color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}.about-links-list{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.about-links-list a{color:var(--accent);text-decoration:none}.about-links-list a:hover{text-decoration:underline}.about-edit-label{font-size:var(--font-size-sm);color:var(--text-secondary)}.about-edit input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);padding:4px 6px}.about-links-edit{flex-direction:column;gap:4px;display:flex}.about-actions{justify-content:flex-end;gap:var(--space-sm);padding:var(--space-md);border-top:1px solid var(--border);background:var(--bg-panel);display:flex}.about-footer{border-top:1px solid var(--border);padding:var(--space-sm) var(--space-md);background:#00000026}.about-mpx-footer{align-items:center;gap:var(--space-md);font-size:var(--font-size-sm);color:var(--text-dim);grid-template-columns:auto 1fr auto;display:grid}.about-mpx-icon img{opacity:.92;border-radius:6px;width:48px;height:48px;transition:transform .15s ease-out,opacity .15s;display:block}.about-mpx-icon img:hover{opacity:1;transform:scale(1.04)}.about-mpx-info{text-align:center;flex-direction:column;align-items:center;gap:2px;display:flex}.about-mpx-action{justify-content:flex-end;gap:var(--space-sm);display:flex}.about-mpx-version{color:var(--text-secondary);font-weight:500}.about-mpx-links{flex-wrap:wrap;justify-content:center;align-items:center;gap:4px;display:flex}.about-mpx-links a{color:var(--accent);text-decoration:none}.about-mpx-links a:hover{text-decoration:underline}.about-mpx-sep{color:var(--text-dim)}.about-mpx-licence{font-size:.75rem}.modal-header{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.modal-title{color:var(--text-primary);font-weight:600}.modal-close{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:2px 6px;font-size:1.2rem;line-height:1}.modal-close:hover{color:var(--text-primary);background:var(--bg-hover)}.confirm-dialog{width:420px}.confirm-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.confirm-body{color:var(--text-secondary);padding:16px 18px;font-size:.85rem;line-height:1.5}.confirm-body p{margin:0}.confirm-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:12px 18px 16px;display:flex}.motd-dialog--warn{border:1px solid var(--warn,#facc15)}.motd-dialog--warn .confirm-header{border-bottom-color:var(--warn,#facc15);background:#facc1514}.motd-dialog--warn .modal-title:before{content:"⚠ ";color:var(--warn,#facc15)}.modal-tabs{border-bottom:1px solid var(--border);display:flex}.modal-tab{color:var(--text-secondary);font-size:var(--font-size-sm);padding:var(--space-xs) var(--space-sm);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;transition:color .15s}.modal-tab:hover{color:var(--text-primary)}.modal-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.modal-body{padding:var(--space-sm) var(--space-md);gap:var(--space-sm);flex-direction:column;flex:1;display:flex;overflow-y:auto}.tab-content{gap:var(--space-sm);flex-direction:column;display:flex}.modal-search-row{gap:var(--space-xs);display:flex}.modal-search-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--font-size-sm);flex:1;padding:5px 8px}.modal-search-input:focus{border-color:var(--border-focus);outline:none}.modal-select{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--font-size-sm);padding:4px 6px}.sound-list{flex-direction:column;gap:4px;min-height:80px;display:flex}.sound-list-empty{color:var(--text-dim);font-size:var(--font-size-sm);text-align:center;padding:var(--space-md)}.sound-row{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--space-xs) var(--space-sm);align-items:flex-start;gap:var(--space-sm);display:flex}.sound-row-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.sound-name{font-size:var(--font-size-sm);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sound-meta{color:var(--text-dim);font-size:.7rem}.sound-license{font-style:italic}.sound-license--attrib{color:var(--warn)}.sound-attrib-hint{color:var(--warn);opacity:.85;font-size:.68rem;font-style:italic}.sound-row-actions{gap:var(--space-xs);flex-shrink:0;align-items:center;display:flex}.fs-more-btn{width:100%;margin-top:var(--space-xs)}.btn--xs{padding:2px 7px;font-size:.7rem}.fs-status{font-size:var(--font-size-sm);color:var(--text-secondary);min-height:18px}.fs-api-section{padding-top:var(--space-sm);border-top:1px solid var(--border);gap:var(--space-xs);flex-direction:column;margin-top:auto;display:flex}.fs-api-label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:600}.fs-api-row{gap:var(--space-xs);display:flex}.fs-api-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--font-size-sm);flex:1;padding:4px 8px}.fs-api-input:focus{border-color:var(--border-focus);outline:none}.fs-api-hint{color:var(--text-dim);font-size:.68rem}.fs-api-link{color:var(--accent);cursor:pointer;text-decoration:underline}.fs-api-link:hover{color:var(--accent-hover)}#attributions-modal{z-index:1100}.attr-intro{font-size:var(--font-size-sm);color:var(--text-secondary)}.attr-list{margin-top:var(--space-xs);flex-direction:column;gap:6px;display:flex}.attr-row{background:var(--bg-input);border-radius:var(--radius-sm);padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-sm);flex-wrap:wrap;align-items:center;gap:6px;display:flex}.attr-text{color:var(--text-primary);flex:1}.attr-license{color:var(--text-dim);font-size:.7rem;font-style:italic}.attr-license--required{color:var(--warn)}.attr-link{color:var(--accent);font-size:.7rem;text-decoration:none}.attr-link:hover{text-decoration:underline}.attr-empty{font-size:var(--font-size-sm);color:var(--text-dim);text-align:center;padding:var(--space-md)}.attr-section-heading{text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);margin:var(--space-sm) 0 4px;border-bottom:1px solid var(--border);padding-bottom:2px;font-size:.7rem}.attr-section-heading:first-child{margin-top:0}.attr-footer{margin-top:var(--space-md);padding-top:var(--space-sm);border-top:1px solid var(--border);align-items:center;gap:var(--space-sm);display:flex}.attr-copy-status{color:var(--text-dim);font-size:.7rem}.upload-drop-zone{border:2px dashed var(--border);border-radius:var(--radius-md);padding:32px var(--space-md);text-align:center;cursor:pointer;color:var(--text-dim);font-size:var(--font-size-sm);margin-bottom:var(--space-sm);line-height:1.6;transition:border-color .15s,color .15s}.upload-drop-zone:hover,.upload-drop-zone--over{border-color:var(--accent);color:var(--text)}.upload-drop-label{pointer-events:none;margin:0}#fog-paint-btn.is-active,#fog-erase-btn.is-active{letter-spacing:0;font-size:0}#fog-paint-btn.is-active:before,#fog-erase-btn.is-active:before{letter-spacing:.08em;font-size:.75rem;font-weight:700}#fog-paint-btn.is-active:before{content:"PAINTING"}#fog-erase-btn.is-active:before{content:"ERASING"}.upload-storage-hint{margin:var(--space-xs) 0 0 0;font-size:var(--font-size-sm);color:var(--text-dim);font-style:italic}.weblinks-hint{font-size:var(--font-size-sm);color:var(--text-dim);margin:0 0 var(--space-sm) 0;line-height:1.4}.weblinks-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);padding:var(--space-sm);resize:vertical;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.8rem}.weblinks-input:focus{border-color:var(--border-focus);outline:none}.weblinks-results{margin-top:var(--space-sm);flex-direction:column;gap:4px;display:flex}.weblinks-result{border-radius:var(--radius-sm);border-left:3px solid var(--border);word-break:break-all;background:#ffffff05;padding:4px 8px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.75rem}.weblinks-result--ok{border-left-color:#22c55e}.weblinks-result--fail{color:var(--text-dim);border-left-color:#dc2626}.weblinks-result--busy{border-left-color:var(--accent);color:var(--text-dim)}.calibration-overlay{z-index:10001;background:#000;position:fixed;inset:0}.calibration-frame{background:#000;flex-direction:column;width:100vw;height:100vh;display:flex}.calibration-header{padding:8px var(--space-md);border-bottom:1px solid var(--border);background:var(--bg-elevated);justify-content:space-between;align-items:center;gap:var(--space-md);display:flex}.calibration-header h3{margin:0 0 2px;font-size:.95rem}.calibration-header p{color:var(--text-dim);margin:0;font-size:.7rem}.calibration-toggle-grid{color:var(--text-dim);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;font-size:.78rem;display:inline-flex}.calibration-toggle-grid input{cursor:pointer;margin:0}.calibration-grid-panel{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:#ffffff08;flex-wrap:wrap;align-items:center;gap:12px;padding:8px 12px;display:flex}.calibration-grid-toggle{border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-dim);cursor:pointer;background:0 0;align-items:center;gap:8px;padding:6px 12px;font-family:inherit;font-size:.85rem;transition:background .12s,color .12s,border-color .12s;display:inline-flex}.calibration-grid-toggle:hover{border-color:var(--border-focus);color:var(--text)}.calibration-grid-toggle__icon-on{display:none}.calibration-grid-toggle__icon-off{display:inline-block}.calibration-grid-panel[data-active=true] .calibration-grid-toggle{color:var(--text);background:#5af07a1f;border-color:#5af07a99}.calibration-grid-panel[data-active=true] .calibration-grid-toggle__icon-on{display:inline-block}.calibration-grid-panel[data-active=true] .calibration-grid-toggle__icon-off{display:none}.calibration-grid-colour-label{color:var(--text-dim);cursor:pointer;align-items:center;gap:6px;font-size:.78rem;display:inline-flex}.calibration-grid-colour-input{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:0 0;width:32px;height:24px;padding:0}.calibration-grid-hint{color:var(--text-dim);flex-wrap:wrap;align-items:center;gap:4px 10px;font-size:.75rem;line-height:1.4;display:inline-flex}.calibration-grid-hint strong{color:var(--text);font-weight:600}.calibration-grid-overlay{stroke:#5af07a}.calibration-grid-overlay line{stroke:inherit;stroke-width:1px;vector-effect:non-scaling-stroke;opacity:.75;pointer-events:none}.calibration-canvas-wrap{cursor:grab;background-color:#050505;background-image:linear-gradient(45deg,#0c0c0c 25%,#0000 25%),linear-gradient(-45deg,#0c0c0c 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#0c0c0c 75%),linear-gradient(-45deg,#0000 75%,#0c0c0c 75%);background-position:0 0,0 8px,8px -8px,-8px 0;background-repeat:repeat;background-size:16px 16px;background-attachment:scroll;background-origin:padding-box;background-clip:border-box;flex:1;position:relative;overflow:hidden}.calibration-canvas-wrap:active{cursor:grabbing}.calibration-svg{-webkit-user-select:none;user-select:none;touch-action:none;width:100%;height:100%;display:block}.calibration-image{pointer-events:none}.calibration-line{fill:none;vector-effect:non-scaling-stroke}.calibration-line-base{stroke:#fbbf24;stroke-width:2px}.calibration-line-ants{stroke:#0a0e1a;stroke-width:2px;stroke-dasharray:6 6;animation:.7s linear infinite cx-march}.calibration-handle .cx-arm{vector-effect:non-scaling-stroke}.calibration-handle .cx-base{stroke:#fbbf24;stroke-width:3px}.calibration-handle .cx-ants{stroke:#0a0e1a;stroke-width:3px;stroke-dasharray:4 4;animation:.6s linear infinite cx-march}.calibration-handle .cx-dot{fill:#fbbf24;stroke:#0a0e1a;stroke-width:1.5px;vector-effect:non-scaling-stroke}.calibration-handle .cx-hit{fill:#0000;pointer-events:all;cursor:grab}.calibration-handle:active .cx-hit{cursor:grabbing}@keyframes cx-march{to{stroke-dashoffset:-12px}}.calibration-footer{padding:var(--space-md);border-top:1px solid var(--border);align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.calibration-distance{align-items:center;gap:8px;font-size:.85rem;display:inline-flex}.calibration-distance-input{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);width:90px;color:var(--text);padding:4px 8px;font-size:.9rem}.calibration-mode-rows{flex-direction:column;gap:6px;display:flex}.calibration-by-grid{color:var(--text-dim);align-items:center;gap:8px;font-size:.85rem;display:inline-flex}.calibration-by-grid input{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);width:64px;color:var(--text);padding:4px 8px;font-size:.9rem}.calibration-grid-feedback{font-family:var(--font-mono);color:var(--text-dim);margin-left:4px;font-size:.78rem}.calibration-grid-feedback.is-ok{color:var(--ok)}.calibration-grid-feedback.is-warn{color:var(--warn)}.calibration-by-dpi{color:var(--text-dim);align-items:center;gap:8px;font-size:.85rem;display:inline-flex}.calibration-by-dpi select{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:4px 8px;font-size:.9rem}.calibration-current{color:var(--text-dim);font-size:.75rem;font-family:var(--font-mono)}.calibration-actions{gap:var(--space-sm);margin-left:auto;display:flex}.map-edit-calibration-state{color:var(--text-dim);font-size:.8rem;font-family:var(--font-mono);flex:1}.player-fullscreen-btn{z-index:100;color:var(--text);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:.25;background:#0009;padding:6px 10px;font-size:.75rem;transition:opacity .25s;position:fixed;bottom:12px;right:12px}.player-fullscreen-btn:hover{opacity:1}.map-upload-bulk-attr{border:1px solid var(--border);border-radius:var(--radius-md);background:#ffffff08;margin-bottom:10px;padding:10px 12px}.map-upload-bulk-attr-row{grid-template-columns:90px 1fr;align-items:center;gap:8px;margin-bottom:6px;display:grid}.map-upload-bulk-attr-row:last-of-type{margin-bottom:0}.map-upload-bulk-attr-row label{color:var(--text-dim);font-size:.78rem}.map-upload-bulk-attr-row input,.map-upload-bulk-attr-row select{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);padding:4px 8px;font-size:.82rem}.map-upload-bulk-hint{color:var(--text-dim);margin:8px 0 0;font-size:.72rem;font-style:italic}.map-upload-queue{flex-direction:column;gap:6px;max-height:280px;margin-bottom:10px;display:flex;overflow-y:auto}.map-upload-queue-row{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);grid-template-columns:1fr auto auto;align-items:center;gap:8px;padding:6px 10px;display:grid}.map-upload-queue-name{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);background:0 0;padding:4px 8px;font-size:.82rem}.map-upload-queue-filename{color:var(--text-dim);text-overflow:ellipsis;white-space:nowrap;max-width:180px;font-size:.72rem;overflow:hidden}.composite-editor-dialog{border-radius:0;flex-direction:column;width:100vw;max-width:none;height:100vh;max-height:none;display:flex}.composite-editor-toolbar{align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border);background:var(--bg-panel);flex-shrink:0;display:flex}.composite-editor-mode-label{color:var(--text);font-size:.85rem;font-weight:600}.composite-editor-hint{color:var(--text-dim);font-size:.78rem;font-style:italic}.composite-editor-canvas-wrap{background:var(--bg);flex:1;display:flex;overflow:hidden}.composite-editor-canvas{cursor:grab;touch-action:none;background:#111;flex:1;position:relative;overflow:hidden}.composite-editor-viewport{transform-origin:0 0;position:absolute;top:0;left:0}.composite-editor-grid{pointer-events:none;position:absolute;inset:0;overflow:visible}.composite-editor-name-label{color:var(--text-dim);align-items:center;gap:6px;font-size:.85rem;display:inline-flex}.composite-editor-name-input{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);min-width:200px;color:var(--text);padding:4px 8px;font-size:.85rem}.composite-editor-name-input:focus{border-color:var(--border-focus);outline:none}.composite-editor-snap-toggle{color:var(--text-dim);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;font-size:.85rem;display:inline-flex}.composite-editor-snap-toggle input{cursor:pointer;margin:0}.composite-editor-grid line{stroke:#ffffff1f;stroke-width:1px;vector-effect:non-scaling-stroke}.composite-editor-tiles{position:absolute;inset:0}.composite-editor-tile{pointer-events:auto;transform-origin:50%;outline-offset:-1px;outline:1px solid #ffffff2e;position:absolute}.composite-editor-tile--centre-snap{outline-offset:-2px;outline:2px solid #5af07af2;box-shadow:0 0 12px #5af07a8c}.composite-editor-undo-group{align-items:center;gap:2px;display:flex}.composite-editor-undo-group .btn[disabled]{opacity:.35;cursor:default;pointer-events:none}.composite-editor-tile-content{transform-origin:50%;position:absolute;inset:0}.composite-editor-tile-content img{-webkit-user-select:none;user-select:none;-webkit-user-drag:none;width:100%;height:100%;display:block}.composite-editor-tile--selected{outline-offset:-2px;z-index:2;outline:2px dashed #5af07ae6}.composite-editor-tile-trash{color:#fff;cursor:pointer;z-index:3;background:#b91c1c;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;padding:0;display:flex;position:absolute;bottom:-14px;left:-14px;box-shadow:0 2px 6px #0006}.composite-editor-tile-trash:hover{background:#dc2626}.composite-editor-tile-flip{color:#fff;cursor:pointer;z-index:3;background:#141824e6;border:1.5px solid #ffffffb3;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;padding:0;display:flex;position:absolute;box-shadow:0 2px 6px #0006}.composite-editor-tile-flip--v{top:-14px;left:50%;transform:translate(-50%)}.composite-editor-tile-flip--h{top:50%;right:-14px;transform:translateY(-50%)}.composite-editor-tile-flip:hover{filter:brightness(1.2)}.composite-editor-tile-flip.is-active{color:#0a0e1a;background:#5af07ad9}.composite-editor-tile-drag{color:#fff;cursor:move;z-index:3;background:#141824e6;border:1.5px solid #ffffffb3;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;padding:0;display:flex;position:absolute;top:-14px;left:-14px;box-shadow:0 2px 6px #0006}.composite-editor-tile-drag:hover{filter:brightness(1.2)}.composite-editor-tile-rotate-stem{pointer-events:none;z-index:2;border-left:1.5px dashed #5af07ad9;width:0;height:28px;position:absolute;top:-28px;left:50%}.composite-editor-tile-rotate-handle{color:#fff;cursor:grab;z-index:3;touch-action:none;background:#141824e6;border:2px solid #5af07ad9;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;padding:0;display:flex;position:absolute;top:-42px;left:50%;transform:translate(-50%);box-shadow:0 2px 6px #0006}.composite-editor-tile-rotate-handle:hover{filter:brightness(1.2)}.composite-editor-tile-rotate-handle:active{cursor:grabbing}.composite-editor-tile-resize{color:#fff;cursor:nwse-resize;z-index:3;touch-action:none;background:#141824e6;border:2px solid #5af07ad9;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;padding:0;display:flex;position:absolute;bottom:-14px;right:-14px;box-shadow:0 2px 6px #0006}.composite-editor-tile-resize:hover{filter:brightness(1.2)}.composite-editor-tile-lock,.composite-editor-tile-reset{color:#fff;cursor:pointer;z-index:3;background:#141824e6;border:1.5px solid #ffffffb3;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;padding:0;display:flex;position:absolute;right:-14px;box-shadow:0 2px 6px #0006}.composite-editor-tile-lock{bottom:22px}.composite-editor-tile-reset{bottom:56px}.composite-editor-tile-lock:hover,.composite-editor-tile-reset:hover{filter:brightness(1.2)}.composite-editor-tile-lock.is-active{color:#0a0e1a;background:#5af07ad9}.composite-editor-tile-context-menu{z-index:10000;color:#e8edf7;-webkit-user-select:none;user-select:none;background:#141824f7;border:1px solid #ffffff2e;border-radius:6px;min-width:180px;padding:4px 0;font-size:.85rem;position:fixed;box-shadow:0 8px 24px #0009}.composite-editor-context-header{color:#ffffff8c;text-transform:uppercase;letter-spacing:.05em;padding:4px 12px 6px;font-size:.75rem}.composite-editor-tile-context-menu button{width:100%;color:inherit;text-align:left;cursor:pointer;font-size:inherit;background:0 0;border:none;padding:6px 12px;font-family:inherit;display:block}.composite-editor-tile-context-menu button:hover:not(:disabled){background:#5af07a2e}.composite-editor-tile-context-menu button:disabled{color:#ffffff40;cursor:default}.composite-editor-context-sep{background:#ffffff1f;height:1px;margin:4px 6px}.composite-editor-context-danger{color:#f87171}.composite-editor-context-danger:hover:not(:disabled){background:#f871712e!important}.composite-editor-footer{justify-content:flex-end;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-top:1px solid var(--border);background:var(--bg-panel);flex-shrink:0;display:flex}.composite-pick-banner{border-radius:var(--radius-md);background:#5af07a1a;border:1px solid #5af07a8c;align-items:center;gap:12px;margin-bottom:8px;padding:10px 14px;display:flex}.composite-pick-banner__text{flex-direction:column;flex:1;gap:2px;font-size:.85rem;line-height:1.35;display:flex}.composite-pick-banner__text strong{color:var(--text)}.composite-pick-banner__text span{color:var(--text-dim);font-size:.78rem}#map-upper-layer-opacity{cursor:pointer;flex:auto;min-width:0}.player-reset-view-btn{z-index:100;color:var(--text);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:.55;background:#0009;padding:6px 10px;font-size:.75rem;transition:opacity .25s;position:fixed;bottom:50px;right:12px}.player-reset-view-btn:hover{opacity:1}.projector-view{color:var(--text);touch-action:none;overscroll-behavior:none;background:#000;margin:0;overflow:hidden}.projector-view #renderer-canvas{width:100vw;height:100vh;display:block;position:fixed;inset:0}.projector-view:not(.projector-view--monitor)[data-rot="180"] #renderer-canvas,.projector-view:not(.projector-view--monitor)[data-rot="180"] .projector-grid{transform:rotate(180deg)}.projector-view:not(.projector-view--monitor)[data-rot="90"] #renderer-canvas,.projector-view:not(.projector-view--monitor)[data-rot="90"] .projector-grid,.projector-view:not(.projector-view--monitor)[data-rot="270"] #renderer-canvas,.projector-view:not(.projector-view--monitor)[data-rot="270"] .projector-grid{width:100vh;height:100vw;position:fixed;inset:50% auto auto 50%}.projector-view:not(.projector-view--monitor)[data-rot="90"] #renderer-canvas,.projector-view:not(.projector-view--monitor)[data-rot="90"] .projector-grid{transform:translate(-50%,-50%)rotate(90deg)}.projector-view:not(.projector-view--monitor)[data-rot="270"] #renderer-canvas,.projector-view:not(.projector-view--monitor)[data-rot="270"] .projector-grid{transform:translate(-50%,-50%)rotate(270deg)}.projector-view--monitor{background:#fff}.projector-view--monitor #renderer-canvas{box-sizing:content-box;width:min(calc(100vw - 16px), calc((100vh - 16px) * var(--monitor-aspect,1)));height:min(calc(100vh - 16px), calc((100vw - 16px) / var(--monitor-aspect,1)));border:8px solid #1a1a1a;border-radius:4px;margin:auto;position:fixed;inset:0;box-shadow:inset 0 0 0 1px #2a2a2a,0 0 0 2px #000}.projector-grid{z-index:40;pointer-events:none;position:fixed;inset:0}.projector-overlay-msg{z-index:45;color:var(--text-dim);letter-spacing:.06em;text-transform:uppercase;pointer-events:none;opacity:1;background:#000;justify-content:center;align-items:center;font-size:1.25rem;transition:opacity 1s ease-out;display:flex;position:fixed;inset:0}.projector-overlay-msg.is-faded{opacity:0}.projector-warn-banner{z-index:45;border-radius:var(--radius-sm);color:#ffd29a;letter-spacing:.04em;pointer-events:none;opacity:1;background:#ff8c002e;border:1px solid #ff8c008c;padding:6px 14px;font-size:.8rem;transition:opacity 1s ease-out;position:fixed;top:12px;left:50%;transform:translate(-50%)}.projector-warn-banner.is-faded{opacity:0}.calibration-prompt{text-align:center;padding:var(--space-lg);color:var(--text);background:#000;flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.calibration-prompt h1{margin:0 0 var(--space-sm);font-size:1.5rem}.calibration-prompt p{margin:0 0 var(--space-md);max-width:480px;color:var(--text-dim)}.projector-controls{border:1px solid var(--border);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:.3;background:#0009;align-items:center;gap:6px;padding:6px 10px;font-size:.75rem;transition:opacity .6s;display:flex;position:fixed;bottom:12px;right:12px}.projector-controls.idle{opacity:0}.projector-controls:hover{opacity:1}.projector-setup-label{color:var(--text-dim);font-family:var(--font-mono);margin-right:4px}.monitor-badge{z-index:50;pointer-events:none;border-radius:var(--radius-md);color:#ff5a5a;letter-spacing:.05em;text-transform:uppercase;font-size:.9rem;font-weight:700;font-family:var(--font-mono);background:#000c;border:1px solid #c43a3a;padding:6px 12px;position:fixed;bottom:12px;left:12px}.pcal-overlay{z-index:10001;background:#000;position:fixed;inset:0}.pcal-frame{background:#000;flex-direction:column;width:100vw;height:100vh;display:flex}.pcal-topbar{padding:8px var(--space-md);border-bottom:1px solid var(--border);background:var(--bg-elevated);justify-content:space-between;align-items:flex-start;gap:var(--space-md);flex-wrap:wrap;display:flex}.pcal-titlewrap h3{margin:0 0 2px;font-size:.95rem}.pcal-titlewrap p{color:var(--text-dim);max-width:60ch;margin:0;font-size:.7rem}.pcal-topbar-actions{align-items:center;gap:6px;display:flex}.pcal-fullscreen{z-index:10002;border:1px solid var(--border);opacity:.4;background:#0009;transition:opacity .25s;position:fixed;bottom:12px;right:12px}.pcal-fullscreen:hover{opacity:1}.pcal-saved-label{color:var(--text-dim);font-size:.7rem}.pcal-saved-select{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);min-width:180px;padding:4px 8px;font-size:.85rem}.pcal-step{background:#050505;flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.pcal-step-intro,.pcal-step-name{padding:var(--space-lg);gap:var(--space-md);overflow-y:auto}.pcal-step-blurb{color:var(--accent);letter-spacing:.05em;text-transform:uppercase;margin:0;font-size:.7rem}.pcal-standalone-banner{color:#ffd29a;border-radius:var(--radius-sm);background:#ff8c001f;border:1px solid #ff8c0080;max-width:60ch;padding:10px 14px;font-size:.95rem;line-height:1.5}.pcal-step-instruction{color:var(--text-primary);max-width:60ch;margin:0;font-size:.95rem;line-height:1.5}.pcal-intro-text{color:var(--text-secondary);max-width:60ch;margin:0;font-size:.95rem;line-height:1.55}.pcal-result-row{align-items:baseline;gap:var(--space-sm);display:flex}.pcal-result-label{color:var(--text-dim);font-size:.85rem}.pcal-method{gap:var(--space-sm);flex-direction:column;display:flex}.pcal-radio{cursor:pointer;border:1px solid var(--border);border-radius:var(--radius-sm);background:#ffffff05;align-items:center;gap:8px;padding:8px 10px;font-size:.95rem;transition:border-color .15s,background .15s;display:inline-flex}.pcal-radio:hover{border-color:var(--accent);background:#ffffff0a}.pcal-radio strong{color:var(--text-primary)}.pcal-lfd-pane{padding:var(--space-lg);gap:var(--space-md);flex-direction:column;align-items:flex-start;display:flex}.pcal-lfd-grid{gap:var(--space-sm) var(--space-md);grid-template-columns:auto 1fr;align-items:center;display:grid}.pcal-lfd-grid label{color:var(--text-dim);font-size:.85rem}.pcal-lfd-grid select{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);min-width:280px;padding:6px 10px;font-size:.95rem}.pcal-lfd-note{color:var(--text-dim);max-width:60ch;margin:0;font-size:.75rem}.pcal-proj-pane{flex-direction:column;flex:1;min-height:0;display:flex}.pcal-proj-pane .pcal-step-instruction{padding:10px var(--space-md);border-bottom:1px solid var(--border);background:#0006}.pcal-proj-grid{background:#0a0a0a;flex:1;width:100%;min-height:0;display:block}.pcal-proj-pane .pcal-sliders{padding:10px var(--space-md);border-top:1px solid var(--border);background:var(--bg-elevated)}.pcal-bottombar{align-items:center;gap:var(--space-md);padding:8px var(--space-md);border-top:1px solid var(--border);background:var(--bg-elevated);flex-wrap:wrap;display:flex}.pcal-sliders{gap:4px var(--space-sm);grid-template-columns:auto minmax(200px,280px) auto minmax(120px,180px);align-items:center;display:grid}.pcal-sliders label{color:var(--text-dim);font-size:.7rem}.pcal-sliders input[type=range]{width:100%}.pcal-result-value{font-family:var(--font-mono);color:var(--accent);white-space:nowrap;font-size:.95rem}.pcal-name-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;max-width:28ch;color:var(--text);padding:6px 10px;font-size:.85rem}.map-preview-popover{pointer-events:none;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);z-index:10000;padding:4px;position:fixed;box-shadow:0 4px 12px #00000080}.map-preview-popover img{object-fit:contain;border-radius:2px;max-width:280px;max-height:210px;display:block}.sound-tag{letter-spacing:.04em;text-transform:uppercase;vertical-align:middle;border:1px solid;border-radius:9px;margin-right:4px;padding:1px 6px;font-size:.62rem;font-weight:600;line-height:1.3;display:inline-block}.sound-tag--freesound{color:#22c55e;border-color:#22c55e66}.sound-tag--url{color:#3b82f6;border-color:#3b82f666}.sound-tag--local{color:#94a3b8;border-color:#94a3b866}.sound-tag--scaled{color:#4ade80;border-color:#4ade8066}.sound-tag--auto-scaled{color:#f97316;border-color:#f9731666}.sound-tag--inferred{color:#fb923c;border-color:#fb923c66}.sound-tag--no-grid{color:#94a3b8;border-color:#94a3b866}.sound-tag--textmap,.sound-tag--composite{color:#a78bfa;border-color:#a78bfa66}.sound-tag--layered{color:#22d3ee;border-color:#22d3ee66}.library-pill-filter{border-bottom:1px solid #ffffff0f;flex-wrap:wrap;gap:6px;margin-bottom:6px;padding:6px 0 4px;display:flex}.library-pill-filter:empty{display:none}.library-filter-pill{cursor:pointer;opacity:.55;background:0 0;transition:opacity .1s,background .1s}.library-filter-pill:hover{opacity:.85}.library-filter-pill.is-active{opacity:1;background:#ffffff1a}.library-filter-clear{color:#fff9;cursor:pointer;background:0 0;border:1px solid #ffffff2e;border-radius:999px;margin-left:auto;padding:2px 10px;font-size:.7rem}.library-filter-clear:hover{color:#fff;border-color:#ffffff73}.sound-tag--animated{color:#2dd4bf;border-color:#2dd4bf66}.map-recal-pill{cursor:pointer;transition:background .15s}.map-recal-pill:hover{background:#fbbf2426}.map-autoscaled-pill{cursor:pointer;transition:background .15s}.map-autoscaled-pill:hover{background:#f9731626}.map-nogrid-pill{cursor:pointer;transition:background .15s}.map-nogrid-pill:hover{background:#94a3b826}.sound-tag--unused{color:#f59e0b;border-color:#f59e0b66}.sound-tags-row{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.sound-unused{color:#f59e0b;cursor:help;margin-right:4px;font-size:.65rem;font-weight:700;display:inline-block}.library-footer{margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--border);flex-direction:column;gap:6px;display:flex}.library-store-status{color:var(--text-dim);text-align:center;min-height:1em;margin:0;font-size:.7rem}.library-store-row{gap:var(--space-xs);display:flex}.library-store-row>.btn{flex:1}.sound-row-wrap{margin-bottom:var(--space-xs);flex-direction:column;gap:4px;display:flex}.sound-row-wrap .sound-row{margin-bottom:0}.sound-meta-row{align-items:center;gap:6px;display:inline-flex}.sound-edit-btn{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:3px;padding:0 2px;font-size:.8rem;line-height:1}.sound-edit-btn:hover{color:var(--accent);background:#48d1cc1a}.ui-icon-btn{justify-content:center;align-items:center;line-height:1;display:inline-flex}.ui-icon-btn>svg{display:block}.sound-row-edit{border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--space-sm);background:#ffffff08;flex-direction:column;gap:6px;display:flex}.sound-edit-row{gap:var(--space-xs);grid-template-columns:80px 1fr;align-items:center;display:grid}.sound-edit-row label{color:var(--text-dim);font-size:.75rem}.sound-edit-row select,.sound-edit-row input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);width:100%;padding:4px 6px;font-size:.8rem}.sound-edit-row select:focus,.sound-edit-row input:focus{border-color:var(--border-focus);outline:none}.sound-edit-actions{gap:var(--space-xs);justify-content:flex-end;margin-top:2px;display:flex}.upload-file-info{gap:var(--space-sm);padding-top:var(--space-xs);flex-direction:column;display:flex}.upload-license-note{font-size:var(--font-size-sm);color:var(--text-dim);margin:0}.upload-actions{gap:var(--space-sm);display:flex}.mute-indicator{border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);z-index:999;cursor:pointer;background:#0a0e1ae0;padding:6px 14px;font-family:inherit;font-size:.85rem;line-height:1;transition:opacity 1s;position:fixed;top:16px;right:16px}.mute-indicator--initial{pointer-events:none;padding:10px 18px;font-size:.95rem}.mute-indicator--interactive{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:1;background:#0009;padding:6px 10px;font-size:1.1rem}.mute-indicator--interactive.mute-indicator--idle{opacity:.25}.mute-indicator--interactive:hover{opacity:1}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-focus)}.players-list{gap:var(--space-xs);margin-bottom:var(--space-sm);flex-direction:column;display:flex}.players-empty{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0;line-height:1.4}.player-row{align-items:center;gap:var(--space-sm);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);padding:4px 6px;display:flex}.player-status-dot{background:var(--text-dim);border-radius:50%;flex:none;width:10px;height:10px;box-shadow:inset 0 0 0 1px #0006}.player-status-dot.is-online{background:var(--ok);animation:2.2s ease-in-out infinite player-status-pulse}@keyframes player-status-pulse{0%,to{box-shadow:0 0 0 0 #22c55e8c, 0 0 4px var(--ok)}60%{box-shadow:0 0 0 6px #22c55e00, 0 0 4px var(--ok)}}.player-row-unread{color:#fff;cursor:pointer;background:#dc2626d9;border:1px solid #ffffff2e;border-radius:999px;flex:none;justify-content:center;align-items:center;min-width:22px;height:20px;padding:0 6px;font-size:.72rem;font-weight:700;transition:background .12s,transform .12s;display:inline-flex}.player-row-unread:hover{background:#dc2626;transform:scale(1.05)}.player-row-unread--peer{background:#f59e0bd9}.player-row-unread--peer:hover{background:#f59e0b}.player-row-thread-idle{border-radius:var(--radius-sm);width:22px;height:20px;color:var(--text-dim);opacity:.55;cursor:pointer;background:0 0;border:1px solid #0000;flex:none;justify-content:center;align-items:center;transition:opacity .12s,color .12s,background .12s,border-color .12s;display:inline-flex}.player-row-thread-idle:hover{opacity:1;color:var(--text-primary);background:#ffffff0d;border-color:#ffffff1f}.player-row-thread-offline{color:#dc2626b3;cursor:default;flex:none;justify-content:center;align-items:center;width:22px;height:20px;display:inline-flex}.player-row{position:relative}.player-row-delete-corner{border:1px solid var(--bg-panel,#11151f);color:#fff;cursor:pointer;opacity:0;pointer-events:none;z-index:2;background:#dc2626e6;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;transition:opacity .12s,transform .12s;display:inline-flex;position:absolute;top:-6px;right:-6px}.player-row:hover .player-row-delete-corner,.player-row-delete-corner:focus-visible{opacity:1;pointer-events:auto}.player-row-delete-corner:hover{background:#dc2626;transform:scale(1.1)}#canvas-wrapper.player-drop-active:before{content:"";pointer-events:none;z-index:40;position:absolute;inset:0;box-shadow:inset 0 0 0 3px #6366f18c}.mt-panel{flex-direction:column;gap:0;height:100%;padding:0;display:flex}.mt-thread{gap:var(--space-sm);padding:var(--space-md) var(--space-sm);flex-direction:column;flex:auto;display:flex;overflow-y:auto}.mt-empty{font-size:var(--font-size-sm);color:var(--text-dim);text-align:center;margin:auto}.mt-msg{border-radius:10px;flex-direction:column;gap:2px;max-width:95%;padding:6px 10px;display:flex}.mt-msg--player{background:#ffffff0a;align-self:flex-start}.mt-msg--gm{background:#6366f12e;align-self:flex-end}.mt-msg--new .mt-msg-from{font-weight:800}.mt-msg--new .mt-msg-text{color:#fff;font-weight:600}.mt-msg-head{align-items:center;gap:var(--space-xs);font-size:.72rem;display:flex}.mt-msg-from{font-weight:600}.mt-msg-arrow{color:#fff;padding:0 2px;font-weight:700}.mt-msg-to{font-weight:700}.mt-msg-time{color:var(--text-dim);margin-left:auto}.mt-msg-text{font-size:var(--font-size-sm);color:var(--text-primary);white-space:pre-wrap;word-break:break-word}.mt-composer{gap:var(--space-xs);padding:var(--space-sm);background:#ffffff05;border-top:1px solid #ffffff14;flex-direction:column;flex:none;display:flex}.mt-chips{flex-wrap:wrap;gap:4px;display:flex}.mt-chip{color:var(--text-secondary);cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1f;border-radius:999px;padding:3px 8px;font-size:.72rem;transition:background .12s,color .12s}.mt-chip:hover{color:var(--text-primary);background:#ffffff1f}.mt-chips-waiting{color:var(--text-dim);align-items:center;padding:0 6px;font-size:.9rem;animation:1.2s ease-in-out infinite mt-chips-waiting-pulse;display:inline-flex}@keyframes mt-chips-waiting-pulse{0%,to{opacity:.35}50%{opacity:.95}}.mt-input{resize:vertical;width:100%;min-height:44px;font-family:inherit;font-size:var(--font-size-sm);background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 8px}.mt-actions{justify-content:flex-end;gap:var(--space-xs);display:flex}.player-row-colour{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:0 0;flex:none;width:22px;height:22px;padding:0}.player-row-colour::-webkit-color-swatch-wrapper{padding:2px}.player-row-colour::-webkit-color-swatch{border:none;border-radius:2px}.player-row-colour.flash-invalid{outline:2px solid var(--danger);outline-offset:1px}.player-row-names{flex-direction:column;flex:auto;gap:2px;min-width:0;display:flex}.player-row-name,.player-row-char{box-sizing:border-box;border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font-ui);font-size:var(--font-size-base);background:0 0;border:1px solid #0000;padding:1px 4px}.player-row-char{font-size:var(--font-size-sm);color:var(--text-secondary)}.player-row-name:hover,.player-row-char:hover{border-color:var(--border)}.player-row-name:focus,.player-row-char:focus{border-color:var(--border-focus);background:var(--bg-base);outline:none}.player-row-delete{border-radius:var(--radius-sm);width:26px;height:26px;color:var(--text-dim);cursor:pointer;background:0 0;border:none;flex:none;justify-content:center;align-items:center;padding:0;display:inline-flex}.player-row-delete:hover{color:var(--danger);background:var(--bg-hover)}.player-row-marker,.player-row-cancelmove{border-radius:var(--radius-sm);width:26px;height:26px;color:var(--text-dim);cursor:pointer;background:0 0;border:none;flex:none;justify-content:center;align-items:center;padding:0;display:inline-flex}.player-row-marker:hover,.player-row-cancelmove:hover{color:var(--text-primary);background:var(--bg-hover)}.player-row-marker.is-placed{color:var(--accent)}.player-row-cancelmove{color:var(--warn)}.player-row-tokensize{appearance:none;background:var(--bg-base);border:1.5px solid var(--bg-panel);height:14px;color:var(--text-primary);font-family:var(--font-ui);cursor:pointer;border-radius:7px;padding:0 3px;font-size:.55rem;font-weight:700;line-height:12px;position:absolute;bottom:-3px;left:-3px;box-shadow:0 0 2px #0009}.player-row-tokensize:hover{border-color:var(--accent)}.player-row-icon-wrap{flex:none;width:34px;height:34px;position:relative}.player-row-icon{background:color-mix(in srgb, var(--row-icon-color,var(--accent)), black 55%);border:2px solid var(--row-icon-color,var(--border));color:#fff;width:34px;height:34px;font-family:var(--font-ui);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:.95rem;font-weight:700;display:inline-flex;overflow:hidden}.player-row-icon img{object-fit:contain;pointer-events:none;width:100%;height:100%}.player-row-icon--empty{opacity:.85;border-style:dashed}.player-row-colour-badge{appearance:none;border:1.5px solid var(--bg-panel);cursor:pointer;border-radius:50%;width:14px;height:14px;padding:0;position:absolute;bottom:-3px;right:-3px;box-shadow:0 0 2px #0009}.player-row-colour-badge::-webkit-color-swatch-wrapper{padding:0}.player-row-colour-badge::-webkit-color-swatch{border:none;border-radius:50%}.player-row-colour-badge::-moz-color-swatch{border:none;border-radius:50%}.player-row-colour-badge.flash-invalid{outline:2px solid var(--danger);outline-offset:1px}.player-row-icon-clear{color:#fff;background:var(--danger);cursor:pointer;z-index:1;border:1px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;padding:0;font-size:12px;line-height:1;display:none;position:absolute;top:-4px;right:-4px}.player-row-icon-wrap:hover .player-row-icon-clear{display:inline-flex}.modal-identity-preview-img{object-fit:contain;pointer-events:none;border-radius:50%;width:100%;height:100%}.player-marker-layer{pointer-events:none;z-index:5;position:absolute;inset:0;overflow:hidden}.pm-token{pointer-events:none;--pm-color:#3b82f6;flex-direction:column;align-items:center;display:flex;position:absolute;transform:translate(-50%,-50%)}.pm-token-disc{background:color-mix(in srgb, var(--pm-color), black 55%);border:3px solid var(--pm-color);color:#fff;width:26px;height:26px;font-family:var(--font-ui);text-shadow:0 1px 2px #000000e6;pointer-events:auto;touch-action:none;border-radius:50%;justify-content:center;align-items:center;font-size:.9rem;font-weight:700;display:flex;overflow:hidden;box-shadow:0 0 6px #0009,inset 0 0 0 1px #ffffff40}.pm-token--draggable .pm-token-disc{cursor:grab}.pm-token.is-dragging .pm-token-disc{cursor:grabbing;box-shadow:0 0 12px var(--pm-color)}.pm-token-disc--has-image,.pm-token-disc--has-glyph{padding:0;font-size:1.05rem}.pm-token-disc img{object-fit:cover;pointer-events:none;width:100%;height:100%;transition:transform .15s}.pm-token-disc--rect{border-radius:12%}.pm-token-disc--scaled{font-size:clamp(.85rem,28%,2rem)}.pm-token-pointer{top:var(--pm-disc-half-h,13px);width:var(--pm-arrow-size,14px);height:var(--pm-arrow-size,14px);margin-left:calc(var(--pm-arrow-size,14px) / -2);margin-top:calc(var(--pm-arrow-size,14px) / -2);background:var(--pm-color);clip-path:polygon(50% 0%,100% 70%,65% 70%,65% 100%,35% 100%,35% 70%,0% 70%);filter:drop-shadow(0 1px 1px #0000008c);pointer-events:none;transform:rotate(var(--pm-facing,0deg)) translateY(var(--pm-pointer-offset,-21px));touch-action:none;transition:transform .15s;position:absolute;left:50%}.pm-token--draggable .pm-token-pointer{pointer-events:auto;cursor:grab}.pm-token.is-rotating .pm-token-pointer{cursor:grabbing;transition:none}.pm-token.is-rotating .pm-token-disc img{transition:none}.pm-token-label{text-overflow:ellipsis;white-space:nowrap;max-width:96px;font-family:var(--font-ui);color:#fff;text-shadow:0 1px 3px #000000f2;margin-top:2px;font-size:.7rem;font-weight:600;overflow:hidden}.annotate-notes,.annotate-clocks{z-index:9;pointer-events:none;position:absolute;inset:0}.anchored-obj{box-sizing:border-box;transform-origin:50%;pointer-events:none;-webkit-user-select:none;user-select:none;position:absolute;container-type:size}.anchored-content{box-sizing:border-box;pointer-events:none;width:100%;height:100%}.anchored-obj.is-selected>.anchored-content{pointer-events:auto}.anchored-obj.is-selected{outline:2px dashed var(--obj-color,var(--accent));outline-offset:2px}.anchored-handle--move{cursor:move;z-index:6;top:0;left:0}.anchored-handle--del{z-index:6;top:100%;left:0}.anchored-handle--resize{cursor:nwse-resize;border-width:2px;border-color:var(--obj-color,#ffffffd9);z-index:6;border-radius:6px;top:100%;left:100%}.anchored-handle--rotate{cursor:grab;z-index:6;top:-32px;left:50%}.anchored-rotate-stem{border-left:2px solid var(--obj-color,#fff9);pointer-events:none;z-index:1;width:0;height:20px;position:absolute;top:-20px;left:50%;transform:translate(-50%)}.a-note>.anchored-content{border:1px solid color-mix(in srgb, var(--note-color,#888), black 25%);border-left:4px solid var(--note-color,#888);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#080b14a8;border-radius:8px;padding:6%;overflow:hidden;box-shadow:0 3px 12px #00000080}.a-note-text{width:100%;height:100%;color:color-mix(in srgb, var(--note-color,#fff), white 35%);font-family:var(--font-ui);white-space:pre-wrap;text-shadow:0 1px 2px #000000d9;font-weight:600;line-height:1.2;overflow:hidden}.a-note-edit{box-sizing:border-box;resize:none;border:1px solid var(--note-color,#fff);color:#fff;width:100%;height:100%;font-family:var(--font-ui);background:#0009;border-radius:4px;outline:none;padding:4px;font-size:.85rem}.textmap-video-layer{z-index:6;pointer-events:none;position:absolute;inset:0}.textmap-video{transform-origin:50%;pointer-events:auto;border-radius:2px;position:absolute;overflow:hidden;box-shadow:0 2px 10px #00000080}.textmap-video iframe{border:0;width:100%;height:100%;display:block}.textmap-alt-text{pointer-events:none;z-index:7;position:absolute;inset:0}.textmap-alt-box{pointer-events:none;position:absolute}.textmap-alt-box:focus,.textmap-alt-box:focus-visible{outline-offset:2px;border-radius:2px;outline:2px solid var(--accent,#5af07a)!important}.sr-only{clip:rect(0, 0, 0, 0);clip-path:inset(50%);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;position:absolute!important}.annotate-whiteboard{z-index:7;pointer-events:none;touch-action:none;width:100%;height:100%;position:absolute;inset:0}.a-clock>.anchored-content{border:1px solid color-mix(in srgb, var(--clock-color,#888), black 30%);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#080b149e;border-radius:10cqmin;flex-direction:column;justify-content:center;align-items:center;gap:2cqh;padding:6cqmin;display:flex;overflow:hidden;box-shadow:0 4px 14px #00000080}.clock-name{color:color-mix(in srgb, var(--clock-color,#fff), white 25%);white-space:nowrap;text-overflow:ellipsis;text-shadow:0 1px 2px #000c;max-width:100%;font-size:13cqh;font-weight:700;overflow:hidden}.clock-dial{aspect-ratio:1;width:auto;height:60cqh;display:block}.clock-wedge{fill:#ffffff0f;stroke:color-mix(in srgb, var(--clock-color,#888), black 10%);stroke-width:1.5px;cursor:pointer;transition:fill .12s}.clock-wedge.is-filled{fill:var(--clock-color,#888)}.clock-wedge:hover{fill:color-mix(in srgb, var(--clock-color,#888), white 20%)}.clock-count{color:color-mix(in srgb, var(--clock-color,#ccc), white 25%);text-shadow:0 1px 2px #000c;font-size:13cqh;font-weight:800}.a-timer>.anchored-content{border:1px solid var(--timer-color,#888);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#080b14a8;border-radius:10cqmin;flex-direction:column;justify-content:center;align-items:center;gap:1cqh;padding:5cqmin 8cqmin;display:flex;overflow:hidden;box-shadow:0 4px 14px #00000080}.a-timer-name{color:color-mix(in srgb, var(--timer-color,#fff), white 25%);white-space:nowrap;text-overflow:ellipsis;text-shadow:0 1px 2px #000c;max-width:100%;font-size:14cqh;font-weight:700;overflow:hidden}.a-timer-time{font-family:var(--font-ui);letter-spacing:.02em;color:var(--timer-color,#fff);text-shadow:0 1px 3px #000000d9;font-variant-numeric:tabular-nums;font-size:42cqh;font-weight:800;line-height:1}.a-timer.is-done .a-timer-time{color:var(--danger);animation:1s ease-in-out infinite a-timer-flash}@keyframes a-timer-flash{50%{opacity:.35}}.anchored-controls{z-index:6;gap:6px;display:flex;position:absolute;top:100%;left:50%;transform:translate(-50%,16px)}.anchored-ctrl{position:relative;transform:none}.anchored-ctrl:active{transform:scale(.94)}.annotate-section-label{margin:var(--space-sm) 0 2px 0;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);font-size:.7rem;font-weight:700}.annotate-section-name-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);padding:4px 6px}.annotate-clock-form{flex-direction:column;gap:6px;display:flex}.annotate-clock-row{align-items:center;gap:8px;display:flex}.annotate-seg-label{font-size:var(--font-size-sm);color:var(--text-secondary)}#annotate-clock-segments{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:52px;color:var(--text-primary);padding:4px 6px}.annotate-timer-mode{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--font-size-sm);padding:4px 6px}#annotate-timer-duration{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:60px;color:var(--text-primary);text-align:center;padding:4px 6px}#annotate-timer-duration:disabled{opacity:.4}.annotate-color-row{flex-wrap:wrap;gap:5px;display:flex}.annotate-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;width:20px;height:20px;padding:0;box-shadow:inset 0 0 0 1px #00000059}.annotate-swatch.is-selected{border-color:#fff;box-shadow:0 0 6px #ffffff80}.annotate-wb-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}#annotate-draw-toggle.is-active{background:var(--accent);border-color:var(--accent);color:#fff}.annotate-sub{border-top:1px solid var(--border);margin-top:6px}.annotate-sub>summary{cursor:pointer;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);-webkit-user-select:none;user-select:none;padding:6px 0 4px 16px;font-size:.7rem;font-weight:700;list-style:none;position:relative}.annotate-sub>summary::-webkit-details-marker{display:none}.annotate-sub>summary:before{content:"▸";font-size:.6rem;transition:transform .15s;position:absolute;left:2px}.annotate-sub[open]>summary:before{transform:rotate(90deg)}.annotate-sub>summary:hover{color:var(--text-primary)}.annotate-note-input{resize:vertical;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font-ui);font-size:var(--font-size-sm);padding:6px 8px}.init-tracker{z-index:8;pointer-events:auto;gap:var(--space-sm);padding:var(--space-sm);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);color:var(--text-primary);font-family:var(--font-ui);background:#0a0e1af0;display:flex;position:absolute}.init-tracker.is-edge-bottom{border-radius:8px 8px 0 0;max-height:55%;bottom:0;left:0;right:0}.init-tracker.is-edge-top{border-radius:0 0 8px 8px;max-height:55%;top:0;left:0;right:0}.init-tracker.is-edge-left{border-radius:0 8px 8px 0;width:116px;top:0;bottom:0;left:0}.init-tracker.is-edge-right{border-radius:8px 0 0 8px;width:116px;top:0;bottom:0;right:0}.init-tracker.is-vertical .init-zone--unallocated{max-width:none}.init-tracker.is-vertical .init-rail.is-vertical{min-width:0}.init-tracker.is-dock-dragging{box-shadow:0 0 0 2px var(--accent), 0 12px 40px #0009;cursor:grabbing;transition:none}.init-edge-hint{z-index:900;pointer-events:none;border:2px dashed var(--accent);background:color-mix(in srgb, var(--accent), transparent 88%);box-sizing:border-box;display:none;position:fixed}.init-edge-hint.is-visible{display:block}.init-card-ghost{z-index:2000;pointer-events:none;opacity:.92;transform:rotate(-3deg)scale(1.04);box-shadow:0 12px 30px #0009;margin:0!important;transition:none!important;position:fixed!important}.init-card-edit{z-index:20;border:1px solid var(--accent);color:#fff;width:auto;font-family:var(--font-ui);text-align:center;background:#000000d1;border-radius:4px;outline:none;padding:2px 4px;font-size:1.1rem;font-weight:800;position:absolute;top:50%;left:16px;right:4px;transform:translateY(-50%)}.init-tracker.is-horizontal{flex-direction:row;align-items:stretch}.init-tracker.is-vertical{flex-direction:column;overflow-y:auto}.init-controls{gap:var(--space-sm);align-items:stretch;display:flex}.init-controls-primary{flex-direction:column;flex-shrink:0;gap:4px;min-width:130px;display:flex}.init-tracker.is-horizontal .init-controls{flex-direction:row;align-items:stretch}.init-tracker.is-vertical .init-controls{flex-direction:column;align-items:stretch}.init-tracker.is-vertical .init-controls-primary{width:84px;min-width:0}.init-tracker.is-vertical .init-btn{white-space:normal;text-align:center;padding:5px 4px;font-size:.72rem;line-height:1.1}.init-drag-bar{cursor:grab;background:#ffffff14;border:1px solid #ffffff26;border-radius:5px;flex-shrink:0;align-self:stretch;width:10px;padding:0;position:relative}.init-drag-bar:before{content:"";background:repeating-linear-gradient(0deg,#0000 0 4px,#ffffff59 4px 6px);border-radius:3px;position:absolute;inset:4px}.init-drag-bar:hover{background:#ffffff2e}.init-tracker.is-vertical .init-drag-bar{width:auto;height:10px}.init-tracker.is-vertical .init-drag-bar:before{background:repeating-linear-gradient(90deg,#0000 0 4px,#ffffff59 4px 6px)}.init-btn{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-ui);font-size:var(--font-size-sm);cursor:pointer;padding:6px 10px}.init-btn:hover{border-color:var(--border-focus);background:var(--bg-hover)}.init-btn--primary{background:var(--accent-dim);border-color:var(--accent);color:var(--accent-hover)}.init-btn--primary:hover{background:var(--accent);color:#fff}.init-btn--danger{color:var(--danger)}.init-btn--danger:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.init-btn--advance{color:#06140b;text-shadow:none;background:linear-gradient(135deg,#22c55e 0%,#16a34a 100%);border:1px solid #15803d;font-weight:700}.init-btn--advance:hover{color:#06140b;background:linear-gradient(135deg,#4ade80 0%,#22c55e 100%)}.init-btn--roll{color:#1c1208;text-shadow:none;background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%);border:1px solid #b45309;font-weight:700}.init-btn--roll:hover{color:#1c1208;background:linear-gradient(135deg,#fbbf24 0%,#f59e0b 100%)}.init-btn.is-disabled{filter:grayscale(.85)brightness(.6);opacity:.55;cursor:not-allowed;pointer-events:auto}.init-btn.is-disabled:hover{background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%)}.init-preserve{color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;padding:2px 2px 0;font-size:.7rem;line-height:1.15;display:flex}.init-preserve input{cursor:pointer;flex-shrink:0;margin:0}.init-preserve:hover{color:var(--text-primary)}.init-sort,.init-edge{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-ui);font-size:var(--font-size-sm);padding:6px 8px}.init-close{width:28px;height:28px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;margin-left:auto;padding:0;font-size:18px}.init-close:hover{color:var(--text-primary)}.init-zones{gap:var(--space-md);flex:1;align-items:flex-start;min-width:0;min-height:0;display:flex}.init-tracker.is-vertical .init-zones{flex-direction:column}.init-zone{flex-direction:column;gap:4px;min-width:0;display:flex}.init-zone--bench{flex:none}.init-zone--unallocated{flex:0 auto;min-width:0;max-width:40%}.init-zone--rail{flex:auto;min-width:0}.init-zone--discard{flex:none}.init-rail-zone{flex:1;min-width:0}.init-stack{flex-shrink:0;width:84px;height:116px;position:relative}.init-stack--discard{width:84px;height:116px}.init-stack .init-card--staging{width:76px;height:100px;transform:translate(calc(var(--stack-pos,0) * 5px), calc(var(--stack-pos,0) * 5px));z-index:calc(var(--stack-size,1) - var(--stack-pos,0));margin:0;transition:transform .2s,box-shadow .2s,opacity .2s;position:absolute;top:0;left:0}.init-stack--bench.is-drop-target,.init-stack--discard.is-drop-target{outline:2px dashed var(--accent);outline-offset:4px;border-radius:10px}.init-stack-spine{top:calc(var(--depth,1) * 3px);left:calc(var(--depth,1) * 3px);width:76px;height:100px;z-index:calc(5 - var(--depth,1));background:linear-gradient(155deg,#0a0a0a 0%,#1a0606 100%);border:1px solid #b91c1c;border-radius:8px;position:absolute;box-shadow:0 1px 2px #00000059}.init-stack-count{color:#1a1006;z-index:200;background:#fbbf24;border:2px solid #1a0606;border-radius:11px;justify-content:center;align-items:center;min-width:22px;height:22px;padding:0 5px;font-size:.65rem;font-weight:900;display:inline-flex;position:absolute;top:-8px;right:-8px;box-shadow:0 1px 3px #00000080}.player-init .init-card--enemy{--init-color:#1f2937;--init-color-fg:#fff;background:linear-gradient(155deg,#1f2937 0%,#0a0d14 100%);border-color:#334155;box-shadow:0 3px 8px #0000008c,inset 0 1px #ffffff0d}.init-row--unallocated{flex-wrap:wrap;align-items:flex-start;gap:12px;padding:4px 2px;display:flex}.init-card--staging{cursor:grab;width:76px;height:100px}.init-card--unallocated{opacity:.96}.init-card--discard,.init-card.is-discarded{filter:grayscale(.6)brightness(.7);cursor:default}.init-card-stage-value{color:#fff;width:auto;font-family:var(--font-ui);text-align:center;text-shadow:none;z-index:5;background:#00000073;border:1px solid #ffffff2e;border-radius:4px;outline:none;padding:2px 4px;font-size:.85rem;font-weight:700;position:absolute;bottom:4px;left:4px;right:4px}.init-card-stage-value:focus{border-color:var(--init-color,var(--accent));box-shadow:0 0 0 2px color-mix(in srgb, var(--init-color,var(--accent)), transparent 60%);background:#000000bf}.init-card-stage-value::placeholder{color:#ffffff73}.init-card--staging .init-card-portrait,.init-card--staging .init-card-disc{pointer-events:none}.init-card-marker-link{z-index:6;color:#ffffffa6;cursor:pointer;background:#00000073;border:0;border-radius:4px;justify-content:center;align-items:center;width:20px;height:20px;padding:0;display:inline-flex;position:absolute;top:2px;left:2px}.init-card-marker-link:hover{color:#fff;background:#000000b3}.init-card-marker-link.is-linked{color:var(--accent,#5af07a)}.init-card-marker-select{z-index:21;border:1px solid var(--accent,#5af07a);color:#fff;max-width:150px;font-family:var(--font-ui);background:#000000e6;border-radius:4px;padding:2px 4px;font-size:.78rem;position:absolute;top:2px;left:2px}.init-card-body--art{position:relative}.init-card-portrait--gm{filter:brightness(.5);z-index:0;pointer-events:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.init-card-body--art .init-card-big{z-index:1;text-shadow:0 1px 3px #000000f2,0 0 5px #000c;position:relative}.init-zone-label{font-size:var(--font-size-sm);text-transform:uppercase;color:var(--text-secondary);letter-spacing:.05em}.init-zone-list{gap:var(--space-xs);flex-wrap:wrap;align-items:center;min-height:30px;display:flex}.init-zone-empty{color:var(--text-dim);font-size:var(--font-size-sm);font-style:italic}.init-chip{background:var(--bg-input);border:2px solid var(--init-color,var(--border));border-radius:var(--radius-sm);min-width:30px;height:30px;color:var(--text-primary);font-family:var(--font-ui);cursor:pointer;justify-content:center;align-items:center;padding:0 8px;font-size:.85rem;font-weight:700;display:inline-flex}.init-chip:hover{background:var(--bg-hover)}.init-chip--enemy{background:color-mix(in srgb, var(--init-color), black 30%);color:#fff}.init-chip--player{background:color-mix(in srgb, var(--init-color), black 60%);color:#fff;padding:0 12px}.init-chip--ghost{opacity:.7;border-style:dashed}.init-rail{align-items:center;min-height:110px;display:flex}.init-rail.is-horizontal{padding:var(--space-sm) 60px var(--space-md) var(--space-sm);flex-direction:row;overflow:auto visible}.init-rail.is-vertical{padding:var(--space-sm) var(--space-md) 60px var(--space-sm);flex-direction:column;min-width:100px;min-height:0;overflow:visible auto}.init-card{background:linear-gradient(155deg, color-mix(in srgb, var(--init-color,#475569), black 45%) 0%, color-mix(in srgb, var(--init-color,#1f2937), black 75%) 100%);border:1px solid color-mix(in srgb, var(--init-color,#475569), white 10%);cursor:grab;border-radius:8px;flex-shrink:0;width:76px;height:100px;transition:transform .2s,opacity .2s,box-shadow .2s;position:relative;box-shadow:0 3px 6px #00000073,inset 0 1px #ffffff14,inset 0 -1px #0000004d}.init-rail.is-horizontal .init-card{margin-right:-20px}.init-rail.is-vertical .init-card{margin-bottom:-32px}.init-card.is-active{transform:scale(1.12);box-shadow:0 0 12px #ffffff2e;z-index:200!important}.init-card.is-dragging{visibility:hidden}.init-card.is-drop-target{outline:2px dashed var(--accent);outline-offset:2px}.init-card.is-gap-shift{transform:translate(90px)}.init-card.is-active.is-gap-shift{transform:translate(90px)scale(1.12)}.init-rail.is-vertical .init-card.is-gap-shift{transform:translateY(110px)}.init-rail.is-vertical .init-card.is-active.is-gap-shift{transform:translateY(110px)scale(1.12)}.init-card--player{background:linear-gradient(135deg, color-mix(in srgb, var(--init-color), black 60%) 0%, color-mix(in srgb, var(--init-color), black 80%) 100%);border-color:var(--init-color)}.init-card--enemy{--init-color:#b91c1c;--init-color-fg:#fff;background:linear-gradient(155deg,#0a0a0a 0%,#1a0606 100%);border-color:#b91c1c;box-shadow:0 3px 6px #0009,0 0 10px #b91c1c33}.init-card--round-marker{--init-color:#fbbf24;--init-color-fg:#1a1006;cursor:default;background:repeating-linear-gradient(-45deg,#fbbf24 0 11px,#000 11px 22px);border:2px solid #fbbf24;box-shadow:0 3px 6px #00000080,0 0 14px #fbbf2459}.init-card-tab{background:var(--init-color);pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute;overflow:hidden}.init-card-tab--left{border-radius:6px 0 0 6px;width:16px;top:0;bottom:0;left:0}.init-card-tab--right{border-radius:0 6px 6px 0;width:16px;top:0;bottom:0;right:0}.init-card-tab--top{border-radius:6px 6px 0 0;height:16px;top:0;left:0;right:0}.init-card-tab--bottom{border-radius:0 0 6px 6px;height:16px;bottom:0;left:0;right:0}.init-rail.is-horizontal .init-card-tab--left,.init-rail.is-horizontal .init-card-tab--top,.init-rail.is-horizontal .init-card-tab--bottom,.init-tracker.is-horizontal .init-card--staging .init-card-tab--left,.init-tracker.is-horizontal .init-card--staging .init-card-tab--top,.init-tracker.is-horizontal .init-card--staging .init-card-tab--bottom,.init-rail.is-vertical .init-card-tab--left,.init-rail.is-vertical .init-card-tab--right,.init-rail.is-vertical .init-card-tab--top,.init-tracker.is-vertical .init-card--staging .init-card-tab--left,.init-tracker.is-vertical .init-card--staging .init-card-tab--right,.init-tracker.is-vertical .init-card--staging .init-card-tab--top{display:none}.init-card-tab-text{color:var(--init-color-fg,#fff);text-shadow:0 1px 2px #000000b3,0 0 2px #0006;white-space:nowrap;text-overflow:clip;letter-spacing:.04em;font-size:.7rem;font-weight:800;overflow:hidden}.init-card--enemy .init-card-tab--left .init-card-tab-text,.init-card--enemy .init-card-tab--right .init-card-tab-text{writing-mode:horizontal-tb;letter-spacing:0;max-height:none;font-size:1rem;font-weight:900;transform:none}.init-card-tab--left .init-card-tab-text{writing-mode:vertical-rl;max-height:88px;transform:rotate(180deg)}.init-card-tab--right .init-card-tab-text{writing-mode:vertical-rl;max-height:88px}.init-card--marker-named.init-card--enemy .init-card-tab--left .init-card-tab-text,.init-card--marker-named.init-card--enemy .init-card-tab--right .init-card-tab-text{writing-mode:vertical-rl;letter-spacing:.04em;max-height:88px;font-size:.7rem;font-weight:800}.init-card--marker-named.init-card--enemy .init-card-tab--left .init-card-tab-text{transform:rotate(180deg)}.init-card--marker-named.init-card--enemy .init-card-tab--right .init-card-tab-text{transform:none}.init-card-tab--top .init-card-tab-text,.init-card-tab--bottom .init-card-tab-text{max-width:calc(100% - 8px)}.init-card-body{color:#fff;text-align:center;text-shadow:0 1px 3px #000000d9;justify-content:center;align-items:center;height:100%;margin:0 16px 0 0;padding:4px;font-weight:700;display:flex}.init-rail.is-vertical .init-card-body{margin:0 0 16px}.init-tracker.is-horizontal .init-card--staging .init-card-body{margin:0 16px 0 0}.init-tracker.is-vertical .init-card--staging .init-card-body{margin:0 0 16px}.init-card-body--marker{letter-spacing:.1em;color:var(--text-secondary);writing-mode:vertical-rl;white-space:nowrap;margin:0;font-size:.6rem;transform:rotate(180deg)}.init-rail.is-vertical .init-card-body--marker{writing-mode:horizontal-tb;margin:0;transform:none}.init-card-body--enemy{letter-spacing:.04em;font-size:.75rem}.init-card-big{font-size:1.6rem;font-weight:800}.init-card-disc{aspect-ratio:1;background:radial-gradient(circle at 30% 25%, color-mix(in srgb, var(--init-color), white 25%) 0%, var(--init-color) 50%, color-mix(in srgb, var(--init-color), black 25%) 100%);border:2px solid var(--init-color-fg,#fff);width:80%;min-width:38px;max-width:86px;color:var(--init-color-fg,#fff);letter-spacing:.02em;border-radius:50%;justify-content:center;align-items:center;font-size:1.6rem;font-weight:900;display:flex;box-shadow:0 3px 8px #0000008c,inset 0 1px 3px #ffffff4d,inset 0 -1px 3px #0000004d}.init-card-portrait{object-fit:cover;border:1.5px solid color-mix(in srgb, var(--init-color), white 15%);-webkit-user-select:none;user-select:none;border-radius:8px;width:92%;height:92%;box-shadow:0 3px 8px #0009,inset 0 0 0 1px #0003}.init-card-duck{object-fit:cover;filter:brightness(.35)contrast(1.1);pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%}.init-card-chrome{opacity:0;pointer-events:none;justify-content:center;align-items:center;gap:2px;transition:opacity .15s;display:flex;position:absolute;bottom:-28px;left:14px;right:14px}.init-rail.is-vertical .init-card-chrome{inset:auto 0 0;transform:translateY(100%)}.init-card:hover .init-card-chrome,.init-card.is-active .init-card-chrome{opacity:1;pointer-events:auto}.init-card-value{background:var(--bg-base);border:1px solid var(--border);width:44px;color:var(--text-primary);font-family:var(--font-ui);text-align:center;border-radius:3px;padding:2px 3px;font-size:.75rem}.init-card-delete{background:var(--bg-base);border:1px solid var(--danger);width:18px;height:18px;color:var(--danger);cursor:pointer;opacity:0;z-index:10;border-radius:50%;padding:0;font-size:13px;line-height:16px;transition:opacity .15s,transform .1s;position:absolute;top:-8px;right:-8px}.init-card:hover .init-card-delete,.init-card.is-active .init-card-delete{opacity:1}.init-card-delete:hover{background:var(--danger);color:#fff;transform:scale(1.1)}.player-init{z-index:8;pointer-events:auto;background:#080b144d;border-radius:12px;width:max-content;max-width:100vw;max-height:100vh;padding:5px;position:fixed;overflow:visible}.player-init.is-edge-bottom{border-radius:12px 12px 0 0;bottom:0;left:50%;transform:translate(-50%)}.player-init.is-edge-top{border-radius:0 0 12px 12px;top:0;left:50%;transform:translate(-50%)}.player-init.is-edge-left{border-radius:0 12px 12px 0;top:50%;left:0;transform:translateY(-50%)}.player-init.is-edge-right{border-radius:12px 0 0 12px;top:50%;right:0;transform:translateY(-50%)}.player-init .init-rail.is-horizontal{min-height:0;padding:4px 24px 4px 4px;overflow:visible}.player-init .init-rail.is-vertical{min-height:0;padding:4px 4px 24px;overflow:visible}.player-init .init-card{border-color:color-mix(in srgb, var(--init-color), black 40%);width:clamp(60px,8vmin,104px);height:clamp(82px,11vmin,140px);box-shadow:0 4px 10px #0000008c,inset 0 1px #ffffff14}.player-init .init-card.is-active{box-shadow:0 6px 16px #0009, 0 0 18px color-mix(in srgb, var(--init-color), transparent 35%);transform-origin:50%;transform:scale(1.22)}.player-init .init-card--round-marker{width:clamp(60px,8vmin,104px);height:clamp(82px,11vmin,140px)}.player-init .init-rail.is-horizontal .init-card{margin-right:clamp(-52px,-4vmin,-28px)}.player-init .init-rail.is-vertical .init-card{margin-bottom:clamp(-72px,-5.5vmin,-38px)}.player-init .init-card-tab-text{font-size:clamp(.6rem,1vmin,.9rem)}.init-roll-overlay{z-index:1500;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:radial-gradient(#000000b3 0%,#000000eb 80%);flex-direction:column;justify-content:center;align-items:center;gap:32px;animation:.24s ease-out init-roll-fade-in;display:flex;position:fixed;inset:0}@keyframes init-roll-fade-in{0%{opacity:0}to{opacity:1}}.init-roll-banner{font-family:var(--font-ui);letter-spacing:.4em;color:#fef3c7;text-shadow:0 0 24px #f97316a6,0 2px 8px #000000e6;-webkit-user-select:none;user-select:none;font-size:2.6rem;font-weight:800;animation:1.6s ease-in-out infinite alternate init-roll-banner-pulse}@keyframes init-roll-banner-pulse{0%{text-shadow:0 0 24px #f973168c,0 2px 8px #000000e6;transform:scale(1)}to{text-shadow:0 0 36px #f97316d9,0 2px 8px #000000e6;transform:scale(1.04)}}.init-roll-card{background:linear-gradient(160deg, color-mix(in srgb, var(--init-color,#1e293b), black 55%) 0%, color-mix(in srgb, var(--init-color,#0f172a), black 80%) 100%);border:1px solid color-mix(in srgb, var(--init-color,#475569), black 30%);width:min(360px,86vw);box-shadow:0 24px 60px #000000b3, 0 0 32px color-mix(in srgb, var(--init-color,#475569), transparent 50%), inset 0 1px 0 #ffffff1a;color:#fff;text-align:center;border-radius:14px;padding:36px 28px 24px;animation:.36s cubic-bezier(.2,.7,.2,1.2) init-roll-card-in;position:relative}@keyframes init-roll-card-in{0%{opacity:0;transform:translateY(20px)scale(.92)}to{opacity:1;transform:translateY(0)scale(1)}}.init-roll-card-tab{background:var(--init-color,#475569);height:8px;position:absolute;left:0;right:0}.init-roll-card-tab--top{border-radius:14px 14px 0 0;top:0}.init-roll-card-tab--bottom{border-radius:0 0 14px 14px;bottom:0}.init-roll-title{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.18em;margin-bottom:var(--space-sm);color:#fff;text-shadow:0 1px 3px #000c;font-size:1.1rem;font-weight:700}.init-roll-note,.init-roll-intro{margin:0 0 var(--space-sm) 0;color:#ffffffb8;font-size:.85rem;line-height:1.45}.init-roll-input{width:100%;margin:var(--space-sm) 0 var(--space-md) 0;border:2px solid var(--init-color,#475569);color:#fff;font-family:var(--font-ui);text-align:center;letter-spacing:.06em;background:#00000073;border-radius:8px;outline:none;padding:14px 16px;font-size:2rem;font-weight:800;box-shadow:inset 0 2px 8px #0000008c}.init-roll-input:focus{border-color:#fef3c7;box-shadow:inset 0 2px 8px #0000008c,0 0 0 3px #fef3c72e}.init-roll-actions{gap:var(--space-sm);justify-content:center;display:flex}.init-roll-skip,.init-roll-send{font-family:var(--font-ui);letter-spacing:.08em;text-transform:uppercase;cursor:pointer;border-radius:8px;flex:1;padding:10px 16px;font-size:.85rem;font-weight:700}.init-roll-skip{color:#ffffffb3;background:0 0;border:1px solid #ffffff40}.init-roll-skip:hover{color:#fff;background:#ffffff14}.init-roll-send{color:#1c1208;background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%);border:1px solid #b45309;box-shadow:0 2px 8px #d9770666,inset 0 1px #ffffff40}.init-roll-send:hover{background:linear-gradient(135deg,#fbbf24 0%,#f59e0b 100%);box-shadow:0 4px 12px #d9770699}.call-initiative-btn{margin:var(--space-sm) 0 var(--space-xs) 0;color:#1c1208;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%);border:1px solid #b45309;padding:10px 14px;font-size:.78rem;font-weight:700;box-shadow:0 2px 6px #d9770659,inset 0 1px #ffffff40}.call-initiative-btn:hover{background:linear-gradient(135deg,#fbbf24 0%,#f59e0b 100%);box-shadow:0 3px 10px #d977068c,inset 0 1px #ffffff4d}.call-initiative-btn:active{transform:translateY(1px);box-shadow:0 1px 3px #d977064d}.player-colour-swatches{gap:var(--space-sm);flex-wrap:wrap;display:flex}.player-colour-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;width:26px;height:26px;padding:0;position:relative;box-shadow:inset 0 0 0 1px #00000059}.player-colour-swatch-taken{background:var(--bg-base);width:13px;height:13px;color:var(--text-primary);font-family:var(--font-ui);pointer-events:none;text-transform:uppercase;border:1.5px solid #fff;border-radius:50%;justify-content:center;align-items:center;font-size:.55rem;font-weight:700;display:flex;position:absolute;top:-3px;right:-3px}.player-colour-swatch.is-selected{border-color:var(--text-primary);box-shadow:0 0 6px #ffffff73}input.player-colour-swatch--custom{appearance:none;cursor:pointer;background:conic-gradient(#ef4444,#f59e0b,#eab308,#22c55e,#14b8a6,#3b82f6,#7c5cff,#c44dd6,#ef4444);padding:0}input.player-colour-swatch--custom::-webkit-color-swatch-wrapper{border:none;padding:0}input.player-colour-swatch--custom::-webkit-color-swatch{background:0 0;border:none;border-radius:50%}input.player-colour-swatch--custom::-moz-color-swatch{background:0 0;border:none;border-radius:50%}input.player-colour-swatch--custom:hover{box-shadow:0 0 6px #ffffff59}.modal-identity-preview{background:var(--accent);color:#fff;width:40px;height:40px;font-family:var(--font-ui);text-shadow:0 1px 2px #000c;border:2px solid #fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.05rem;font-weight:700;display:inline-flex;box-shadow:0 2px 8px #0000008c}body.is-gm-preview #renderer-canvas,body.is-gm-preview .pm-token-disc{pointer-events:none!important}body.is-gm-preview .player-action-menu{display:none!important}body.is-gm-preview .player-init{pointer-events:none}.player-identity-btn{z-index:20;border:1px solid var(--border);color:var(--text-primary);font-family:var(--font-ui);cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:.55;background:#0a0e1ab3;border-radius:999px;align-items:center;gap:8px;padding:6px 12px 6px 8px;font-size:.85rem;transition:opacity .25s,background .25s;display:inline-flex;position:fixed;top:12px;left:12px}.player-identity-btn:hover{opacity:1;background:#0a0e1ae6}.player-identity-btn--prompting{opacity:1;animation:1.7s ease-in-out infinite pill-pulse}.player-identity-btn--prompting:hover{opacity:1}@keyframes pill-pulse{0%,to{box-shadow:0 0 #0d9adb8c}60%{box-shadow:0 0 0 10px #0d9adb00}}.player-identity-dot{background:0 0;border-radius:50%;width:12px;height:12px;box-shadow:inset 0 0 0 1px #ffffff80}.player-identity-label{white-space:nowrap;text-overflow:ellipsis;max-width:40vw;overflow:hidden}.ping-layer{pointer-events:none;z-index:6;position:absolute;inset:0;overflow:hidden}.measure-layer{pointer-events:none;z-index:12;position:absolute;inset:0;overflow:visible}.measure-capture{pointer-events:auto;cursor:crosshair;touch-action:none;background:0 0;position:absolute;inset:0}.measure-svg{pointer-events:none;width:100%;height:100%;transition:opacity .6s;position:absolute;inset:0;overflow:visible}.measure-svg.is-fading{opacity:0}.measure-line{stroke:#fbbf24;stroke-width:2.5px;stroke-linecap:round;filter:drop-shadow(0 1px 2px #000000b3)}.measure-line.is-live{stroke-dasharray:7 5;opacity:.9}.measure-cap{fill:#fbbf24;stroke:#0009;stroke-width:1px}.measure-label{pointer-events:none;color:#fde68a;font-family:var(--font-mono,monospace);white-space:nowrap;background:#11151fe6;border:1px solid #fbbf24;border-radius:999px;padding:2px 8px;font-size:.8rem;font-weight:700;transition:opacity .6s;position:absolute;transform:translate(-50%,-160%);box-shadow:0 2px 8px #00000080}.measure-label.is-fading{opacity:0}.ping{pointer-events:none;--ping-color:#3b82f6;position:absolute;transform:translate(-50%,-50%)}.ping-dot{background:var(--ping-color);width:12px;height:12px;box-shadow:0 0 8px var(--ping-color), 0 0 0 1.5px #ffffffd9;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.ping-ring{border:2.5px solid var(--ping-color);border-radius:50%;width:28px;height:28px;margin:-14px 0 0 -14px;animation:1.35s linear infinite ping-zero-in;position:absolute;top:50%;left:50%}@keyframes ping-zero-in{0%{opacity:0;transform:scale(3)}25%{opacity:.95}to{opacity:0;transform:scale(.45)}}.ping-label{white-space:nowrap;font-family:var(--font-ui);color:#fff;text-shadow:0 1px 3px #000000e6;background:#0a0e1a99;border-radius:999px;padding:1px 6px;font-size:.72rem;font-weight:600;position:absolute;top:16px;left:50%;transform:translate(-50%)}.ping-dismiss{color:#fff;background:var(--danger);cursor:pointer;pointer-events:auto;border:1.5px solid #ffffffb3;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;padding:0;font-size:14px;line-height:1;display:inline-flex;position:absolute;top:-10px;left:12px}.ping-dismiss:hover{background:var(--danger-hover)}.player-action-menu{z-index:40;border:1px solid var(--border);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0a0e1af5;min-width:150px;padding:4px;position:fixed;box-shadow:0 6px 24px #00000080}.player-action-menu-item{text-align:left;border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font-ui);cursor:pointer;background:0 0;border:none;padding:8px 12px;font-size:.9rem;display:block}.player-action-menu-item:hover:not(:disabled){background:var(--bg-hover)}.player-action-menu-item:disabled{color:var(--text-dim);cursor:default}.pv-badge{color:#fff;background:var(--danger);vertical-align:middle;border-radius:999px;justify-content:center;align-items:center;min-width:18px;height:18px;margin-left:6px;padding:0 5px;font-size:.7rem;font-weight:700;display:inline-flex}.pv-list{gap:var(--space-sm);flex-direction:column;max-height:320px;display:flex;overflow-y:auto}.pv-msg{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);padding:6px 8px}.pv-msg-head{align-items:baseline;gap:6px;margin-bottom:2px;display:flex}.pv-msg-from{font-weight:700;font-size:var(--font-size-sm)}.pv-msg-to{font-size:var(--font-size-sm);color:var(--text-secondary)}.pv-msg-time{color:var(--text-dim);margin-left:auto;font-size:.68rem}.pv-msg-text{font-size:var(--font-size-base);color:var(--text-primary);white-space:pre-wrap;word-break:break-word}.pv-msg-reply-btn{margin-top:4px}.pv-reply-box{flex-direction:column;gap:6px;margin-top:6px;display:flex}.pv-reply-suggestions{flex-direction:column;gap:4px;display:flex}.pv-suggestion{text-align:left;font-size:var(--font-size-sm);color:var(--text-primary);background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;padding:5px 8px}.pv-suggestion:hover{border-color:var(--border-focus);background:var(--bg-hover)}.pv-reply-input{box-sizing:border-box;resize:vertical;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font-ui);font-size:var(--font-size-base);padding:5px 7px}.pv-reply-actions{justify-content:flex-end;gap:var(--space-sm);display:flex}.player-message-input{box-sizing:border-box;resize:vertical;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font-ui);font-size:var(--font-size-base);padding:8px}.player-msg-toasts{z-index:30;pointer-events:none;flex-direction:column;gap:8px;max-width:min(80vw,320px);display:flex;position:fixed;top:56px;right:12px}.player-msg-toast{pointer-events:auto;border:1px solid var(--border);border-left:4px solid var(--from-color,var(--accent));border-radius:var(--radius-md);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0a0e1af0;overflow:hidden;box-shadow:0 6px 20px #00000080}.player-msg-toast-head{align-items:center;gap:6px;padding:6px 8px 2px;display:flex}.player-msg-toast-from{color:var(--from-color,var(--accent));font-size:.8rem;font-weight:700}.player-msg-toast-close{width:20px;height:20px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;margin-left:auto;padding:0;font-size:16px;line-height:1}.player-msg-toast-close:hover{color:var(--text-primary)}.player-msg-toast-body{color:var(--text-primary);white-space:pre-wrap;word-break:break-word;padding:0 8px 8px;font-size:.85rem}
