: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:#1ab5ff;--accent-dim:#0d4a6e;--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}*,: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{width:100%;height:100%;position:relative}#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}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-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-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}.panel-title:hover{color:var(--text-primary);background:#1e3a5f8c}.panel-title:after{content:"▸";flex-shrink:0;font-size:.65rem;transition:transform .18s}.panel-title[aria-expanded=true]:after{transform:rotate(90deg)}.panel-body{gap:var(--space-sm);padding:var(--space-sm) var(--space-md) var(--space-md);flex-direction:column;display:flex}.room-code-row{align-items:center;gap:var(--space-sm);display:flex}.room-code{font-family:var(--font-mono);color:var(--code-text);background:var(--code-bg);padding:2px var(--space-sm);border-radius:var(--radius-sm);border:1px solid var(--accent-dim);text-align:center;letter-spacing:.05em;flex:1;font-size:.9rem}#qr-container{padding:var(--space-xs);justify-content:center;display:flex}#qr-container canvas{border-radius:var(--radius-sm)}.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-full{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);padding:var(--space-sm);font-size:var(--font-size-base);cursor:pointer;outline:none}.select-full:focus{border-color:var(--border-focus)}.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}.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)}.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}.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{padding:4px var(--space-md) 6px;font-family:var(--font-mono);color:var(--text-dim);text-align:right;letter-spacing:.05em;opacity:.5;font-size:.65rem}#gm-markers-canvas{pointer-events:auto;z-index:1}.marker-hud{z-index:15;gap:var(--space-xs);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-xs);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:auto;background:#0a0e1ad9;display:flex;position:absolute}.marker-hud-btn{border:1px solid var(--border);border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-primary);cursor:pointer;background:0 0;justify-content:center;align-items:center;font-size:14px;line-height:1;display:flex}.marker-hud-btn:hover{background:var(--bg-hover)}.marker-hud-btn--danger{border-color:var(--danger);color:var(--danger)}.marker-hud-btn--danger:hover{background:var(--danger);color:#fff}.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}.icon-picker{z-index:1000;background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-sm);width:256px;position:fixed;box-shadow:0 4px 20px #000000a6}.icon-picker-section-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);padding:var(--space-xs) 0 2px;font-size:.65rem;font-weight:600}.icon-picker-grid{grid-template-columns:repeat(8,1fr);gap:2px;display:grid}.icon-picker-btn{background:var(--bg-input);border-radius:var(--radius-sm);cursor:pointer;width:28px;height:28px;color:var(--text-primary);border:1px solid #0000;justify-content:center;align-items:center;font-size:14px;display:flex}.icon-picker-btn:hover{background:var(--bg-hover);border-color:var(--border)}.icon-picker-btn--active{border-color:var(--accent);background:var(--accent-dim)}.icon-picker-btn img{object-fit:contain;width:18px;height:18px}.icon-picker-sep{background:var(--border);height:1px;margin:var(--space-xs) 0}.icon-picker-upload{width:100%;padding:var(--space-xs) var(--space-sm);margin-top:var(--space-xs);border:1px dashed var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--font-size-sm);text-align:center;cursor:pointer;background:0 0;display:block}.icon-picker-upload:hover{border-color:var(--accent);color:var(--accent)}::-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)}
