: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;--sidebar-width:280px;--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;flex-direction:column;gap:1px;display:flex;overflow:hidden auto}#main-area{background:#000;position:relative;overflow:hidden}#canvas-wrapper{cursor:grab;width:100%;height:100%;position:relative;overflow:hidden}.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-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-handle--rect-move{cursor:move;top:0;left:0}.marker-handle--rect-resize{cursor:nwse-resize;top:100%;left:100%}.marker-handle--rect-maximise{cursor:pointer;top:0;left:30px}.marker-handle--rect-aspect{cursor:pointer;top:0;left:60px}.marker-selection-ring{width:calc(2 * var(--icon-half-w,0px) + 10px);height:calc(2 * var(--icon-half-h,0px) + 10px);pointer-events:none;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(var(--icon-half-h,0px) + 4px);cursor:grab;left:0}.marker-handle--rotate:active{cursor:grabbing}#projector-viewport-canvas{z-index:4;pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.projector-status{color:var(--text-secondary);font-size:.75rem;font-family:var(--font-mono);margin:0;line-height:1.4}body.player-view{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}#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--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)}.panel-body{gap:var(--space-sm);padding:var(--space-sm) var(--space-md) var(--space-md);flex-direction:column;display:flex}#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}.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)}.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}.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}.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-toolbar{gap:var(--space-xs);flex-wrap:wrap;align-items:center;display:flex}.fog-hint{color:var(--text-dim);font-size:.7rem;line-height:1.4}.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%}.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)}.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:none;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--image .txt-map-el-body{cursor:grab;padding:0;display:block}.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-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;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;bottom:-11px;right:-11px}.txt-map-el-delete{color:#ffc4c4;border-color:#dc5050d9;top:-11px;right:-11px}.txt-map-el-delete:hover{color:#fff;background:#b42828f2;border-color:#ff8080}.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-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-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);background:var(--bg-deep,#00000026);justify-content:flex-end;display:flex}.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:600px}.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{padding:var(--space-md);gap:var(--space-md);flex-direction:column;flex:1;display:flex;overflow-y:auto}.settings-section{gap:var(--space-sm);padding:var(--space-md);border:1px solid var(--border);border-radius:var(--radius-md);background:#ffffff05;flex-direction:column;display:flex}.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-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-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}.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-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)}.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}.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-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-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}.projector-view{color:var(--text);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:35;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:#fbbf24;border-color:#fbbf2466}.sound-tag--auto-scaled{color:#f97316;border-color:#f9731666}.sound-tag--no-grid{color:#94a3b8;border-color:#94a3b866}.sound-tag--textmap{color:#a78bfa;border-color:#a78bfa66}.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-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}.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);pointer-events:none;z-index:999;background:#0a0e1ae0;padding:6px 14px;font-size:.85rem;transition:opacity 1s;position:fixed;top:16px;right:16px}.mute-indicator--hiding{opacity:0}::-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)}
