:root{--color-primary:#6366f1;--color-primary-dark:#4f46e5;--color-primary-rgb:99, 102, 241;--color-danger:#ef4444;--color-danger-rgb:239, 68, 68;--color-success:#22c55e;--color-success-rgb:34, 197, 94;--text-primary:#1f2937;--text-body:#374151;--text-secondary:#6b7280;--text-muted:#94a3b8;--font-sans:-apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Helvetica Neue", sans-serif;--font-mono:ui-monospace, "SF Mono", "Menlo", monospace;--radius-xs:4px;--radius-sm:6px;--radius-md:8px;--radius-lg:10px;--radius-xl:12px;--radius-2xl:16px;--shadow-sm:0 1px 4px #0000000f;--shadow-md:0 4px 12px #0000001a;--shadow-lg:0 8px 32px #00000026, 0 1px 4px #0000000f;--shadow-xl:0 20px 60px #0000004d;--focus-ring:0 0 0 3px #6366f11a}html{overflow:visible}html.is-spatial{--xr-background-material:regular;background-color:#0000;height:100vh;overflow:hidden}html.is-spatial body{height:100vh;overflow:hidden}*{box-sizing:border-box}body{font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0;overflow:visible}.app-layout{grid-template-columns:280px 1fr 320px;width:100vw;height:100vh;display:grid;overflow:visible}.left-sidebar,.right-sidebar{background:#f8fafcfa;border-right:1px solid #0000000f;flex-direction:column;display:flex;overflow:hidden}html.is-spatial .left-sidebar,html.is-spatial .right-sidebar{-webkit-backdrop-filter:blur(40px);backdrop-filter:blur(40px);background:#ffffff47}.left-sidebar{border-right:1px solid #0000000f}.right-sidebar{border-left:1px solid #0000000f;border-right:none}.main-canvas{position:relative;overflow:visible}.board{--canvas-grid-color:#ffffff14;cursor:grab;background:linear-gradient(135deg,#1a1a1f 0%,#232329 60%,#28282f 100%);width:100%;height:100vh;min-height:600px;position:relative;overflow:hidden}.board:before{content:"";background-image:radial-gradient(circle, var(--canvas-grid-color) 1px, transparent 1px);pointer-events:none;z-index:0;background-size:40px 40px;position:absolute;inset:0}html[data-canvas-bg=dark] .board{--canvas-grid-color:#ffffff14;background:linear-gradient(135deg,#1a1a1f 0%,#232329 60%,#28282f 100%)}html[data-canvas-bg=light] .board{--canvas-grid-color:#00000012;background:linear-gradient(135deg,#eceae6 0%,#e0ded9 100%)}html[data-canvas-bg=glass] .board{--canvas-grid-color:#ffffff14;background:linear-gradient(135deg,#1a1a1f 0%,#232329 60%,#28282f 100%)}html.is-spatial .board{background:0 0}html.is-spatial .board:before{display:none}.board:active{cursor:grabbing}.board-canvas{width:100%;height:100%;padding:60px;position:absolute;top:0;left:0}html.is-spatial .board{touch-action:none;scrollbar-width:none;overflow:auto}html.is-spatial .board::-webkit-scrollbar{display:none}.board.placement-mode{cursor:crosshair}.board-scene-container{position:relative}.inline-sidebar{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:900;background:#f8fafcfa;flex-direction:column;width:280px;animation:.2s ease-out sidebarSlideIn;display:flex;position:fixed;top:0;bottom:0;overflow:hidden;box-shadow:0 0 20px #00000014}.inline-sidebar-left{border-right:1px solid #00000014;left:0}.inline-sidebar-right{border-left:1px solid #00000014;width:320px;right:0}@keyframes sidebarSlideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.inline-sidebar-right{animation-name:sidebarSlideInRight}@keyframes sidebarSlideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.inline-sidebar-header{background:#ffffff80;border-bottom:1px solid #0000000f;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.inline-sidebar-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-body);font-size:13px;font-weight:700}.inline-sidebar-close{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;background:#0000000d;border:none;justify-content:center;align-items:center;font-size:16px;transition:all .15s;display:flex}.inline-sidebar-close:hover{color:var(--text-body);background:#0000001a}.inline-sidebar-content{flex:1;overflow-y:auto}.floating-panel{z-index:2000;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border-radius:var(--radius-2xl);box-shadow:var(--shadow-lg);background:#f8fafcfa;border:1px solid #00000014;flex-direction:column;display:flex;position:fixed;overflow:hidden}.floating-panel-palette{width:260px;max-height:80vh;top:80px;right:20px}.floating-panel-layers{width:260px;max-height:70vh;top:80px;left:20px}.floating-panel-controls{width:300px;max-height:80vh;top:80px;right:290px}.floating-panel-help{width:360px;max-height:80vh;top:80px;right:20px}.floating-panel-review{width:300px;max-height:70vh;top:80px;left:50%;transform:translate(-50%)}.floating-panel-header{background:#ffffff80;border-bottom:1px solid #0000000f;align-items:center;gap:4px;padding:8px 12px;display:flex}.floating-panel-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-body);flex:1;font-size:12px;font-weight:700}.floating-panel-close{border-radius:var(--radius-sm);width:24px;height:24px;color:var(--text-secondary);cursor:pointer;background:#0000000d;border:none;justify-content:center;align-items:center;font-size:14px;transition:all .15s;display:flex}.floating-panel-close:hover{color:var(--text-body);background:#0000001a}.floating-panel-content{flex:1;padding:12px;overflow-y:auto}.floating-panel .palette-swatches{gap:8px}.floating-panel .palette-swatch{border-color:#0000001a;height:52px}.floating-panel .palette-swatch:hover{border-color:rgba(var(--color-primary-rgb), .5)}.floating-panel .palette-status{color:#64748b}.floating-panel .palette-status-extracted{color:var(--color-primary-dark);background:rgba(var(--color-primary-rgb), .08)}.floating-panel .palette-reset-btn{color:#64748b;background:0 0;border-color:#00000026}.floating-panel .palette-hint{color:#64748b;background:#0000000a}.floating-panel .palette-swatch-label{background:#0009}.item{border-radius:var(--radius-2xl);-webkit-user-select:none;user-select:none;touch-action:none;cursor:move;--xr-background-material:thin;--xr-z-index:0;background:#fffffffa;border:1px solid #ffffffb3;padding:8px;transition:box-shadow .2s cubic-bezier(.4,0,.2,1),border-color .2s cubic-bezier(.4,0,.2,1),opacity .15s cubic-bezier(.4,0,.2,1);position:absolute;overflow:visible;box-shadow:0 4px 20px #0000001f,0 1px 4px #00000014}.drag-ghost{box-shadow:var(--shadow-lg);will-change:left, top;cursor:grabbing!important;transition:none!important}html.is-spatial .item{background:#ffffffe6}html.is-spatial .drag-ghost{background:#fffffff2}html.is-spatial .item-handle{opacity:1;height:48px}html.is-spatial .item-rotate-handle,html.is-spatial .item-scale-handle{border-width:2px;width:32px;height:32px;font-size:14px}html.is-spatial .item-delete-button{border-width:2px;width:28px;height:28px;font-size:15px}html.is-spatial .item-edit-button{border-width:3px;padding:8px 18px;font-size:13px}html.is-spatial .spatial-btn{width:56px;height:56px}html.is-spatial .spatial-btn-sm{width:48px;height:48px}html.is-spatial .spatial-btn-icon{font-size:24px}html.is-spatial .spatial-btn-sm .spatial-btn-icon{font-size:20px}html.is-spatial .spatial-create-bar,html.is-spatial .spatial-app-bar,html.is-spatial .spatial-utility-bar,html.is-spatial .spatial-selection-bar{gap:10px;padding:12px 20px}html.is-spatial .present-ctrl-btn{width:44px;height:44px;font-size:18px}html.is-spatial .present-ctrl-btn-sm{width:36px;height:36px;font-size:14px}html.is-spatial .item-review-badge{border-width:3px;width:26px;height:26px;font-size:13px}html.is-spatial .tag-pill{padding:6px 14px;font-size:13px}.item:hover{box-shadow:0 8px 30px rgba(var(--color-primary-rgb), .15), 0 2px 8px #0000001a;border-color:rgba(var(--color-primary-rgb), .3)}.item[aria-selected=true]{outline:3px solid rgba(var(--color-primary-rgb), .9);outline-offset:3px;box-shadow:0 4px 16px rgba(var(--color-primary-rgb), .15);border-color:rgba(var(--color-primary-rgb), .5)}.item[aria-selected=true]:hover{outline-color:rgba(var(--color-primary-rgb), 1)}.item.locked{cursor:not-allowed;opacity:.85}.item.locked:not([aria-selected=true]):after{content:"";pointer-events:none;opacity:.7;background:currentColor;width:14px;height:14px;position:absolute;top:4px;right:4px;-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='11' width='18' height='11' rx='2' ry='2'/%3E%3Cpath d='M7 11V7a5 5 0 0 1 10 0v4'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='11' width='18' height='11' rx='2' ry='2'/%3E%3Cpath d='M7 11V7a5 5 0 0 1 10 0v4'/%3E%3C/svg%3E");-webkit-mask-size:contain;mask-size:contain}.item-content{justify-content:center;align-items:center;min-width:60px;min-height:60px;display:flex}.item:has(.item-image){padding:0;overflow:hidden}.item:has(.item-image) .item-handle{z-index:2;background:linear-gradient(#00000026,#0000);border-radius:16px 16px 0 0;position:absolute;top:0;left:0;right:0}.item:has(.item-image) .item-handle:after{color:#ffffffb3}.item-image{object-fit:cover;border-radius:0;width:100%;height:100%;display:block}.item-swatch{border:3px solid #fff9;border-radius:14px;width:120px;height:120px;box-shadow:inset 0 2px 4px #0000001a}.item-text{color:#1e293b;border-radius:var(--radius-lg);letter-spacing:-.01em;word-wrap:break-word;background:#fffffff2;max-width:300px;padding:12px 20px;font-size:14px;font-weight:600;line-height:1.4}html.is-spatial .item-text{background:#ffffffb3}.item-model{border-radius:var(--radius-md);background:linear-gradient(135deg,#f8fafc 0%,#e2e8f0 100%);width:200px;height:200px;position:relative;overflow:hidden}.item-model model-viewer{--poster-color:transparent;width:100%;height:100%}.item-model:after{content:"3D";color:#fff;border-radius:var(--radius-xs);pointer-events:none;background:#ea580cd9;padding:2px 6px;font-size:10px;font-weight:700;position:absolute;top:6px;right:6px}.item:has(.item-note-content){box-shadow:inset 0 0 0 1000px #fff3,0 4px 20px #0000001f,0 1px 4px #00000014}.item-note-content{white-space:pre-wrap;word-wrap:break-word;color:#0f172ad9;width:100%;height:100%;min-height:60px;padding:16px 20px;font-size:14px;font-weight:500;line-height:1.6;overflow:auto}.item-note-textarea{color:#1e293b;resize:none;background:0 0;border:none;outline:none;width:100%;height:100%;min-height:120px;padding:12px 16px;font-family:inherit;font-size:14px;line-height:1.5}.item-embed{border-radius:var(--radius-md);background:#0f172a;width:100%;height:100%;min-height:120px;position:relative;overflow:hidden}.item-embed iframe{pointer-events:auto}.item-embed-error{width:100%;height:100%;min-height:120px;color:var(--color-danger);background:rgba(var(--color-danger-rgb), .05);border-radius:var(--radius-md);justify-content:center;align-items:center;font-size:14px;font-weight:500;display:flex}.item-resize-handle{cursor:nwse-resize;z-index:20;background:rgba(var(--color-primary-rgb), .9);border-radius:var(--radius-xs);touch-action:none;border:2px solid #fff;width:20px;height:20px;transition:transform .15s;position:absolute;bottom:-4px;right:-4px;box-shadow:0 2px 6px #00000026}.item-resize-handle:hover{transform:scale(1.2)}.item[data-group-id]{outline-offset:4px}.item[data-group-id][aria-selected=true]{outline:3px solid rgba(var(--color-primary-rgb), .9);outline-offset:2px;box-shadow:0 0 0 6px rgba(var(--color-primary-rgb), .15), 0 4px 16px #00000014}.item-handle{cursor:move;opacity:0;z-index:1;background:0 0;border-radius:16px 16px 0 0;justify-content:center;align-items:center;height:28px;transition:opacity .15s;display:flex;position:absolute;top:0;left:0;right:0}.item:hover .item-handle{opacity:1;background:linear-gradient(#0000000a,#0000)}.item-handle:after{content:""}.item-delete-button{color:#fff;cursor:pointer;z-index:12;-webkit-user-select:none;user-select:none;background:#64646ed9;border:1.5px solid #fffc;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:13px;font-weight:400;line-height:1;transition:all .15s;display:flex;position:absolute;top:-8px;left:-8px;box-shadow:0 1px 4px #0003}.item-delete-button:hover{background:#dc3c3ce6;transform:scale(1.1);box-shadow:0 2px 8px #00000040}.item-delete-button:active{transform:scale(.9)}.item-review-badge{pointer-events:auto;cursor:default;z-index:10;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:11px;font-weight:700;display:flex;position:absolute;top:-8px;right:-8px;box-shadow:0 1px 4px #0003}.item-review-badge-approved{background:var(--color-success);color:#fff}.item-review-badge-needs-revision{color:#fff;background:#f59e0b}.item-review-badge-commented{color:#fff;background:#3b82f6;font-size:9px}.spatial-btn-approve{color:#16a34a}.spatial-btn-approve:hover:not(:disabled){background:rgba(var(--color-success-rgb), .15)!important;color:#16a34a!important}.spatial-btn-flag{color:#d97706}.spatial-btn-flag:hover:not(:disabled){color:#d97706!important;background:#f59e0b26!important}.spatial-selection-bar .spatial-btn-approve{color:#86efac}.spatial-selection-bar .spatial-btn-flag{color:#fcd34d}.item-rotate-handle,.item-scale-handle{color:#fff;cursor:pointer;z-index:10;-webkit-user-select:none;user-select:none;background:#64646ed9;border:1.5px solid #fffc;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:11px;transition:all .15s;display:flex;position:absolute;box-shadow:0 1px 4px #0003}.item-rotate-handle{top:-8px;right:-8px}.item-scale-handle{bottom:-8px;right:-8px}.item-rotate-handle:hover,.item-scale-handle:hover{background:rgba(var(--color-primary-rgb), .9);transform:scale(1.1);box-shadow:0 2px 8px #00000040}.item-rotate-handle:active,.item-scale-handle:active{transform:scale(.95)}.toolbar-input{opacity:0;pointer-events:none;width:0;height:0;position:absolute;overflow:hidden}.bar-drag-handle{cursor:grab;border-radius:var(--radius-sm);-webkit-user-select:none;user-select:none;touch-action:none;letter-spacing:-.05em;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:28px;font-size:12px;transition:color .15s,background .15s;display:flex}.spatial-selection-bar .bar-drag-handle,.tag-bar-inner .bar-drag-handle{color:#ffffff4d}.spatial-selection-bar .bar-drag-handle:hover,.tag-bar-inner .bar-drag-handle:hover{color:#fff9;background:#ffffff14}.spatial-create-bar .bar-drag-handle,.spatial-app-bar .bar-drag-handle,.spatial-utility-bar .bar-drag-handle{color:#0003}.spatial-create-bar .bar-drag-handle:hover,.spatial-app-bar .bar-drag-handle:hover,.spatial-utility-bar .bar-drag-handle:hover{color:#00000073;background:#0000000d}.bar-drag-handle:active{cursor:grabbing}body.is-bar-dragging{cursor:grabbing!important}body.is-bar-dragging iframe{pointer-events:none}html.is-spatial .bar-drag-handle{display:none}.spatial-create-bar,.spatial-app-bar,.spatial-utility-bar,.spatial-selection-bar{-webkit-backdrop-filter:blur(40px);backdrop-filter:blur(40px);-webkit-user-select:none;user-select:none;z-index:1000;--xr-background-material:thick;--xr-z-index:100;background:#fffffff2;border:1px solid #fff9;border-radius:28px;flex-direction:row;align-items:center;gap:8px;padding:10px 16px;display:flex;box-shadow:0 4px 20px #0000001a}html.is-spatial .spatial-create-bar,html.is-spatial .spatial-app-bar,html.is-spatial .spatial-utility-bar,html.is-spatial .spatial-selection-bar{background:#fff6;border:1px solid #ffffff80}.spatial-create-bar{--xr-back:0;position:fixed;bottom:20px;left:50%;transform:translate(-50%)}.spatial-app-bar{--xr-back:0;position:fixed;top:16px;left:16px}.spatial-utility-bar{--xr-back:0;position:fixed;top:16px;right:16px}.spatial-selection-bar{--xr-back:0;--xr-z-index:200;-webkit-backdrop-filter:blur(32px);backdrop-filter:blur(32px);background:#1e1b4beb;border:1px solid #fff3;gap:6px;padding:8px 12px;position:fixed;bottom:90px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #00000059,inset 0 1px #ffffff26}html.is-spatial .spatial-selection-bar{--xr-background-material:regular;background:#ffffff59}.spatial-selection-bar .spatial-btn{color:#fffffff2;background:#ffffff1f}.spatial-selection-bar .spatial-btn:hover:not(:disabled){background:rgba(var(--color-primary-rgb), .35);color:#fff}.spatial-selection-bar .spatial-separator{background:linear-gradient(#0000,#fff3,#0000)}.spatial-btn{width:48px;height:48px;color:var(--text-body);border-radius:var(--radius-xl);cursor:pointer;-webkit-user-select:none;user-select:none;background:#0000000a;border:none;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:2px;padding:4px;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.spatial-btn:hover:not(:disabled){background:rgba(var(--color-primary-rgb), .12);transform:scale(1.05)}.spatial-btn:active:not(:disabled){transform:scale(.94)}.spatial-btn:disabled{cursor:not-allowed;opacity:.45}.spatial-btn-sm{border-radius:var(--radius-lg);width:40px;height:40px}.spatial-btn-icon{pointer-events:none;justify-content:center;align-items:center;font-size:22px;line-height:1;display:flex}.spatial-btn-icon svg{width:1em;height:1em}.spatial-btn-sm .spatial-btn-icon{font-size:18px}.spatial-btn-label{text-transform:uppercase;letter-spacing:.03em;pointer-events:none;font-size:11px;font-weight:700;line-height:1}.spatial-btn-primary{background:linear-gradient(135deg, var(--color-primary), #8b5cf6);color:#fff;box-shadow:0 2px 8px rgba(var(--color-primary-rgb), .3)}.spatial-btn-primary:hover:not(:disabled){box-shadow:0 4px 16px rgba(var(--color-primary-rgb), .5);background:linear-gradient(135deg,#7c3aed,#a855f7)}.spatial-btn-secondary{color:var(--text-secondary);background:#6b728026}.spatial-btn-secondary:hover:not(:disabled){color:var(--text-body);background:#6b728026}.spatial-btn-accent{color:#059669;box-shadow:none;background:#10b9811f}.spatial-btn-accent:hover:not(:disabled){color:#047857;background:#10b98133}.spatial-btn-danger{background:linear-gradient(135deg, var(--color-danger), #dc2626);color:#fff;box-shadow:0 2px 8px rgba(var(--color-danger-rgb), .3)}.spatial-btn-danger:hover:not(:disabled){background:linear-gradient(135deg, #f87171, var(--color-danger));box-shadow:0 4px 16px rgba(var(--color-danger-rgb), .5)}.spatial-btn-active{color:#fff;background:linear-gradient(135deg,#eab308,#ca8a04);box-shadow:0 2px 8px #eab3084d}.spatial-separator{background:linear-gradient(#0000,#0000001f,#0000);flex-shrink:0;width:1px;height:32px;margin:0 2px}.spatial-selection-bar .spatial-separator{height:24px}.spatial-popover{-webkit-backdrop-filter:blur(40px);backdrop-filter:blur(40px);border-radius:var(--radius-2xl);min-width:180px;box-shadow:var(--shadow-lg);z-index:1100;background:#fffffff7;border:1px solid #fff9;flex-direction:column;gap:2px;padding:8px;display:flex;position:absolute}html.is-spatial .spatial-popover{--xr-background-material:regular;background:#ffffff80;border:1px solid #fff6}.spatial-popover-fixed{z-index:1200;--xr-back:80;--xr-z-index:300}html.is-spatial .spatial-popover-fixed .spatial-popover-item{cursor:pointer;gap:12px;padding:12px 18px;font-size:15px}.spatial-popover-above{margin-bottom:10px;bottom:100%;right:0}.spatial-popover-below{margin-top:10px;top:100%;right:0}.spatial-popover-item{border-radius:var(--radius-lg);cursor:pointer;color:var(--text-body);white-space:nowrap;background:0 0;border:none;flex-direction:row;align-items:center;gap:10px;padding:10px 14px;font-size:14px;font-weight:500;transition:background .15s;display:flex}.spatial-popover-item:hover{background:rgba(var(--color-primary-rgb), .1)}.spatial-popover-item:active{background:rgba(var(--color-primary-rgb), .18)}.spatial-popover-item-danger{color:#dc2626}.spatial-popover-item-danger:hover{background:rgba(var(--color-danger-rgb), .1)}.spatial-popover-icon{text-align:center;flex-shrink:0;justify-content:center;align-items:center;width:24px;font-size:20px;display:flex}.spatial-popover-icon svg{width:1em;height:1em}.spatial-popover-label{flex:1}.spatial-board-name-btn{border-radius:var(--radius-lg);cursor:pointer;background:#0000000f;border:1px solid #00000014;flex-direction:row;align-items:center;gap:6px;height:40px;padding:6px 12px;transition:background .15s;display:flex}.spatial-board-name-btn:hover{background:rgba(var(--color-primary-rgb), .12);border-color:rgba(var(--color-primary-rgb), .2)}.spatial-board-name{color:#111827;text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:14px;font-weight:700;overflow:hidden}html.is-spatial .spatial-board-name{color:#fffffff2}html.is-spatial .spatial-board-name-btn{background:#ffffff14;border-color:#ffffff26}html.is-spatial .spatial-board-name-btn:hover{background:#ffffff26}.spatial-board-chevron{color:var(--text-secondary);pointer-events:none;font-size:10px}.depth-slider-container{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:var(--shadow-lg);--xr-background-material:thick;--xr-back:12;background:#fffffffa;border:1px solid #ffffff80;border-radius:20px;min-width:240px;padding:20px;position:fixed;top:24px;right:24px}html.is-spatial .depth-slider-container{background:#ffffff40}.depth-slider-header{align-items:center;gap:8px;margin-bottom:16px;display:flex}.depth-icon{font-size:20px}.depth-slider-label{color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:700}.depth-steps-visual{justify-content:center;align-items:flex-end;gap:12px;height:60px;margin-bottom:16px;display:flex}.depth-step{cursor:pointer;flex:1;justify-content:center;align-items:flex-end;transition:all .2s;display:flex}.depth-step:not(.disabled):hover .depth-step-bar{transform:scale(1.1);opacity:.8!important}.depth-step-bar{background:linear-gradient(180deg, rgba(var(--color-primary-rgb), .9), #8b5cf6e6);width:100%;max-width:40px;box-shadow:0 2px 8px rgba(var(--color-primary-rgb), .2);border-radius:6px 6px 0 0;transition:all .25s cubic-bezier(.4,0,.2,1)}.depth-step.active .depth-step-bar{background:linear-gradient(180deg, rgba(var(--color-primary-rgb), 1), #8b5cf6);box-shadow:0 4px 16px rgba(var(--color-primary-rgb), .4)}.depth-slider{appearance:none;border-radius:var(--radius-xs);background:linear-gradient(90deg, #e5e7eb 0%, var(--color-primary) 50%, #8b5cf6 100%);cursor:pointer;outline:none;width:100%;height:8px;margin:12px 0}.depth-slider:disabled{opacity:.4;cursor:not-allowed}.depth-slider::-webkit-slider-thumb{appearance:none;background:linear-gradient(135deg, var(--color-primary), #8b5cf6);cursor:pointer;width:24px;height:24px;box-shadow:0 4px 8px rgba(var(--color-primary-rgb), .3);border:3px solid #fff;border-radius:50%;transition:all .2s}.depth-slider::-webkit-slider-thumb:hover{box-shadow:0 6px 16px rgba(var(--color-primary-rgb), .5);transform:scale(1.15)}.depth-slider::-moz-range-thumb{background:linear-gradient(135deg, var(--color-primary), #8b5cf6);cursor:pointer;width:24px;height:24px;box-shadow:0 4px 8px rgba(var(--color-primary-rgb), .3);border:3px solid #fff;border-radius:50%;transition:all .2s}.depth-slider::-moz-range-thumb:hover{box-shadow:0 6px 16px rgba(var(--color-primary-rgb), .5);transform:scale(1.15)}.depth-value{flex-direction:column;align-items:center;gap:4px;margin-top:12px;display:flex}.depth-value-number{color:var(--color-primary);font-size:24px;font-weight:700;line-height:1}.depth-value-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.depth-hint{text-align:center;color:#9ca3af;border-top:1px solid #0000001a;justify-content:center;align-items:center;gap:6px;margin-top:12px;padding-top:12px;font-size:11px;display:flex}.depth-hint kbd{border-radius:var(--radius-xs);font-size:11px;font-weight:600;font-family:var(--font-mono);background:#0000000d;border:1px solid #0000001a;padding:2px 6px}.color-input{border-radius:var(--radius-md);cursor:pointer;appearance:none;background:0 0;border:2px solid #ffffff80;width:40px;height:40px}.color-input::-webkit-color-swatch-wrapper{padding:0}.color-input::-webkit-color-swatch{border-radius:var(--radius-sm);border:none}.color-input::-moz-color-swatch{border-radius:var(--radius-sm);border:none}.palette-scene{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);width:100%;height:100%;padding:24px;overflow-y:auto}html.is-spatial .palette-scene{--xr-background-material:translucent;background:0 0}.palette-title{color:#fff;text-align:center;margin-bottom:16px;font-size:18px;font-weight:600}.palette-status{text-align:center;color:#ffffffb3;border-radius:var(--radius-md);background:#ffffff1a;justify-content:center;align-items:center;gap:8px;margin-bottom:12px;padding:8px 12px;font-size:11px;display:flex}.palette-status-extracted{color:#ffffffe6;background:rgba(var(--color-primary-rgb), .2)}.palette-reset-btn{color:#fffc;border-radius:var(--radius-xs);cursor:pointer;background:0 0;border:1px solid #ffffff4d;padding:2px 8px;font-size:10px;transition:all .15s}.palette-reset-btn:hover{color:#fff;background:#ffffff26}.palette-swatches{flex-direction:column;gap:12px;display:flex}.palette-swatch{border-radius:var(--radius-xl);cursor:pointer;--xr-background-material:thin;border:3px solid #ffffff4d;width:100%;height:80px;transition:all .2s;position:relative}.palette-swatch:hover{border-color:#fffc;transform:scale(1.05)}.palette-swatch-label{color:#fff;border-radius:var(--radius-xs);font-size:11px;font-weight:500;font-family:var(--font-mono);background:#000000b3;padding:4px 8px;position:absolute;bottom:8px;left:50%;transform:translate(-50%)}.palette-hint{border-radius:var(--radius-md);color:#ffffffb3;text-align:center;background:#ffffff26;margin-top:16px;padding:10px 12px;font-size:12px;line-height:1.4}.inline-sidebar .palette-content{padding:8px 0}.inline-sidebar .palette-swatches{gap:8px}.inline-sidebar .palette-swatch{border-color:#0000001a;height:56px}.inline-sidebar .palette-swatch:hover{border-color:rgba(var(--color-primary-rgb), .5)}.inline-sidebar .palette-status{color:#64748b}.inline-sidebar .palette-status-extracted{color:var(--color-primary-dark);background:rgba(var(--color-primary-rgb), .08)}.inline-sidebar .palette-reset-btn{color:#64748b;background:0 0;border-color:#00000026}.inline-sidebar .palette-reset-btn:hover{color:#1e293b;background:#0000000d}.inline-sidebar .palette-hint{color:#64748b;background:#0000000a}.inline-sidebar .palette-swatch-label{background:#0009}.present-mode-active .item{transition:all .3s cubic-bezier(.4,0,.2,1)}.present-mode-active .item.dimmed{opacity:.4}.present-mode-active .item.active{opacity:1}.present-control-bar{-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);z-index:10002;color:#fff;background:#0f172aeb;border:1px solid #ffffff1f;border-radius:14px;align-items:center;gap:8px;padding:8px 16px;font-size:13px;display:flex;position:fixed;top:16px;left:50%;transform:translate(-50%);box-shadow:0 8px 40px #0006}.present-ctrl-btn{border-radius:var(--radius-md);color:#fff;cursor:pointer;background:#ffffff1a;border:none;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;transition:background .15s;display:flex}.present-ctrl-btn:hover:not(:disabled){background:#fff3}.present-ctrl-btn:disabled{opacity:.3;cursor:not-allowed}.present-ctrl-btn.active{background:rgba(var(--color-primary-rgb), .6)}.present-ctrl-btn-sm{width:30px;height:30px;font-size:12px}.present-ctrl-stop{background:rgba(var(--color-danger-rgb), .6);width:auto;padding:0 12px;font-size:12px;font-weight:600}.present-ctrl-stop:hover{background:rgba(var(--color-danger-rgb), .85)!important}.present-ctrl-info{flex-direction:column;align-items:center;gap:2px;min-width:80px;display:flex}.present-ctrl-step{font-variant-numeric:tabular-nums;font-size:15px;font-weight:700}.present-ctrl-label{color:#fff9;text-transform:uppercase;letter-spacing:.05em;text-overflow:ellipsis;white-space:nowrap;max-width:120px;font-size:10px;overflow:hidden}.present-ctrl-sep{background:#ffffff26;width:1px;height:24px}.present-ctrl-btn.recording{background:rgba(var(--color-danger-rgb), .7);animation:1.2s ease-in-out infinite recording-pulse}@keyframes recording-pulse{0%,to{opacity:1}50%{opacity:.6}}.present-notes-panel{z-index:10002;width:480px;max-width:90vw;position:fixed;bottom:20px;left:50%;transform:translate(-50%)}.present-notes-textarea{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-xl);color:#ffffffd9;resize:vertical;background:#0f172ad9;border:1px solid #ffffff1a;outline:none;width:100%;min-height:80px;max-height:160px;padding:12px 16px;font-family:inherit;font-size:13px;line-height:1.5}.present-notes-textarea::placeholder{color:#ffffff4d}.present-notes-textarea:focus{border-color:rgba(var(--color-primary-rgb), .5)}.review-summary{padding:8px 0}.review-progress{padding:0 0 12px}.review-progress-bar{background:#00000014;border-radius:3px;height:6px;margin-bottom:4px;overflow:hidden}.review-progress-fill{background:var(--color-success);border-radius:3px;height:100%;transition:width .3s}.review-progress-label{color:#64748b;font-size:11px}.review-group{border-top:1px solid #0000000f}.review-group-header{cursor:pointer;width:100%;color:var(--text-body);text-align:left;background:0 0;border:none;align-items:center;gap:6px;padding:8px 4px;font-size:13px;font-weight:600;display:flex}.review-group-header:hover{background:#00000008}.review-group-icon{text-align:center;width:18px;font-size:14px}.review-group-count{color:var(--text-muted);font-weight:400}.review-group-chevron{color:var(--text-muted);margin-left:auto;font-size:11px}.review-group-items{padding:0 0 4px 24px}.review-item{cursor:pointer;color:#4b5563;text-align:left;border-radius:var(--radius-xs);background:0 0;border:none;align-items:center;gap:6px;width:100%;padding:4px 8px;font-size:12px;display:flex}.review-item:hover{background:rgba(var(--color-primary-rgb), .08);color:var(--color-primary-dark)}.review-item-icon{flex-shrink:0;font-size:12px}.review-item-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.review-item-comment{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:120px;font-size:10px;font-style:italic;overflow:hidden}.review-bulk-actions{gap:8px;padding:0 0 12px;display:flex}.review-bulk-btn{border-radius:var(--radius-md);cursor:pointer;background:#00000008;border:1px solid #0000001a;flex:1;padding:8px 12px;font-size:12px;font-weight:600;transition:all .15s}.review-bulk-approve{color:#16a34a}.review-bulk-approve:hover{background:rgba(var(--color-success-rgb), .1);border-color:rgba(var(--color-success-rgb), .3)}.review-bulk-clear{color:#64748b}.review-bulk-clear:hover{background:#0000000d}.review-item-row{align-items:center;gap:4px;display:flex}.review-item-row .review-item{flex:1;min-width:0}.review-item-actions{flex-shrink:0;gap:2px;display:flex}.review-action-btn{border-radius:var(--radius-sm);cursor:pointer;background:#00000008;border:1px solid #00000014;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:700;transition:all .15s;display:flex}.review-action-approve{color:var(--text-muted)}.review-action-approve:hover,.review-action-approve.active{background:rgba(var(--color-success-rgb), .15);border-color:rgba(var(--color-success-rgb), .3);color:#16a34a}.review-action-flag{color:var(--text-muted)}.review-action-flag:hover,.review-action-flag.active{color:#d97706;background:#f59e0b26;border-color:#f59e0b4d}.review-scene .review-bulk-btn{background:#ffffff0f;border-color:#ffffff26}.review-scene .review-bulk-approve{color:#86efac}.review-scene .review-bulk-approve:hover{background:rgba(var(--color-success-rgb), .2)}.review-scene .review-bulk-clear{color:#ffffff80}.review-scene .review-action-btn{color:#fff6;background:#ffffff0f;border-color:#ffffff1f}.review-scene .review-action-approve:hover,.review-scene .review-action-approve.active{background:rgba(var(--color-success-rgb), .25);color:#86efac}.review-scene .review-action-flag:hover,.review-scene .review-action-flag.active{color:#fcd34d;background:#f59e0b40}html.is-spatial .review-scene .review-action-btn{border-radius:var(--radius-lg);width:40px;height:40px;font-size:16px}html.is-spatial .review-scene .review-bulk-btn{border-radius:var(--radius-lg);padding:12px 16px;font-size:15px}.review-empty{text-align:center;color:var(--text-muted);padding:24px 0;font-size:13px}.review-scene{color:#fff;background:linear-gradient(135deg,#18181c 0%,#222227 100%);min-height:100vh;padding:24px}.review-scene-title{margin-bottom:16px;font-size:18px;font-weight:700}.review-scene .review-progress-bar{background:#ffffff26}.review-scene .review-group-header{color:#ffffffe6}.review-scene .review-group-header:hover{background:#ffffff14}.review-scene .review-group-count{color:#ffffff80}.review-scene .review-group-chevron{color:#fff6}.review-scene .review-group{border-top-color:#ffffff1a}.review-scene .review-item{color:#ffffffbf}.review-scene .review-item:hover{background:rgba(var(--color-primary-rgb), .2);color:#fff}.review-scene .review-item-comment{color:#fff6}.review-scene .review-progress-label{color:#fff9}.review-scene .review-empty{color:#ffffff80}html.is-spatial .review-scene{--xr-background-material:translucent;background:0 0;padding:28px 32px}html.is-spatial .review-scene-title{margin-bottom:20px;font-size:22px}html.is-spatial .review-scene .review-progress{padding-bottom:16px}html.is-spatial .review-scene .review-progress-bar{border-radius:5px;height:10px;margin-bottom:8px}html.is-spatial .review-scene .review-progress-label{font-size:14px}html.is-spatial .review-scene .review-group-header{cursor:pointer;gap:10px;padding:14px 8px;font-size:16px}html.is-spatial .review-scene .review-group-icon{width:24px;font-size:18px}html.is-spatial .review-scene .review-group-count,html.is-spatial .review-scene .review-group-chevron{font-size:14px}html.is-spatial .review-scene .review-group-items{padding:4px 0 8px 28px}html.is-spatial .review-scene .review-item{border-radius:var(--radius-md);cursor:pointer;gap:10px;padding:10px 12px;font-size:15px}html.is-spatial .review-scene .review-item-icon{font-size:16px}html.is-spatial .review-scene .review-item-comment{font-size:12px}html.is-spatial .review-scene .review-empty{padding:32px 0;font-size:16px}.present-ctrl-timing{color:#fff;border-radius:var(--radius-sm);cursor:pointer;background:#ffffff1a;border:1px solid #ffffff26;outline:none;padding:4px 6px;font-size:11px}.present-ctrl-timing option{color:#fff;background:#1e293b}.presenter-scene{font-family:var(--font-sans);color:#e2e8f0;background:linear-gradient(#0f172a 0%,#1e293b 100%);flex-direction:column;gap:16px;min-height:100vh;padding:20px;display:flex}.presenter-header{justify-content:space-between;align-items:center;display:flex}.presenter-title{color:#fff;margin:0;font-size:20px;font-weight:700}.presenter-status{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);background:#ffffff14;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:700}.presenter-status.live{background:rgba(var(--color-danger-rgb), .15);color:#f87171}.presenter-controls{flex-direction:column;gap:10px;display:flex}.presenter-btn{border-radius:var(--radius-lg);cursor:pointer;border:none;padding:10px 16px;font-size:14px;font-weight:600;transition:all .15s}.presenter-btn-start{background:linear-gradient(135deg, var(--color-primary) 0%, #8b5cf6 100%);color:#fff;box-shadow:0 4px 12px rgba(var(--color-primary-rgb), .3)}.presenter-btn-start:hover{box-shadow:0 6px 20px rgba(var(--color-primary-rgb), .5);transform:translateY(-1px)}.presenter-btn-stop{background:rgba(var(--color-danger-rgb), .2);color:#f87171;border:1px solid rgba(var(--color-danger-rgb), .3)}.presenter-btn-stop:hover{background:rgba(var(--color-danger-rgb), .3)}.presenter-nav{align-items:center;gap:12px;display:flex}.presenter-btn-nav{color:#fff;background:#ffffff14;flex:none;padding:10px 20px}.presenter-btn-nav:hover:not(:disabled){background:#ffffff26}.presenter-btn-nav:disabled{opacity:.3;cursor:not-allowed}.presenter-step-info{text-align:center;flex:1}.presenter-step-num{font-variant-numeric:tabular-nums;color:#fff;font-size:24px;font-weight:800;display:block}.presenter-step-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:2px;font-size:12px;display:block}.presenter-progress{background:#ffffff14;border-radius:2px;width:100%;height:4px;overflow:hidden}.presenter-progress-bar{background:linear-gradient(90deg, var(--color-primary) 0%, #8b5cf6 100%);border-radius:2px;height:100%;transition:width .3s}.presenter-overview{border-radius:var(--radius-xl);background:#ffffff0a;border:1px solid #ffffff0f;padding:14px}.presenter-section-title{text-transform:uppercase;letter-spacing:.1em;color:#64748b;margin:0 0 10px;font-size:11px;font-weight:700}.presenter-stats{gap:12px;display:flex}.presenter-stat{text-align:center;flex:1}.presenter-stat-num{color:#fff;font-size:20px;font-weight:800;display:block}.presenter-stat-label{color:#64748b;text-transform:uppercase;letter-spacing:.05em;font-size:10px;display:block}.presenter-tags{border-radius:var(--radius-xl);background:#ffffff0a;border:1px solid #ffffff0f;max-height:200px;padding:14px;overflow-y:auto}.presenter-tag-list{flex-direction:column;gap:6px;display:flex}.presenter-tag-item{border-radius:var(--radius-md);background:#ffffff0a;justify-content:space-between;align-items:center;padding:6px 10px;display:flex}.presenter-tag-name{color:#cbd5e1;font-size:13px}.presenter-tag-count{color:#64748b;border-radius:var(--radius-lg);background:#ffffff0f;padding:2px 8px;font-size:11px;font-weight:600}.presenter-hints{color:#475569;justify-content:center;gap:16px;margin-top:auto;font-size:11px;display:flex}.button,.chip,.handle,.toolbar-button,.palette-swatch,.color-input,.depth-slider,.item-handle{cursor:pointer}.hidden{display:none}.loading{color:#fff;justify-content:center;align-items:center;height:100vh;font-size:18px;display:flex}.layers-panel{--xr-background-material:thin;flex-direction:column;height:100%;display:flex;overflow:visible}.layers-header{border-bottom:1px solid #0000000f;justify-content:space-between;align-items:center;padding:20px;display:flex}.layers-title{color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;margin:0;font-size:16px;font-weight:700}.layers-count{background:rgba(var(--color-primary-rgb), .1);color:var(--color-primary);border-radius:var(--radius-xl);padding:4px 10px;font-size:12px;font-weight:600}.layers-hint{background:linear-gradient(135deg, rgba(var(--color-primary-rgb), .05), #8b5cf60d);border-bottom:1px solid rgba(var(--color-primary-rgb), .1);justify-content:center;align-items:center;gap:6px;padding:8px 16px;display:flex}.layers-hint-icon{color:var(--color-primary);font-size:14px;line-height:1}.layers-hint-text{color:var(--color-primary);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.layers-search{border-bottom:1px solid #0000000f;padding:12px 16px}.layers-search-input{border-radius:var(--radius-lg);background:#fffc;border:1px solid #0000001a;outline:none;width:100%;padding:10px 14px;font-size:13px;transition:all .2s}.layers-search-input:focus{border-color:var(--color-primary);box-shadow:var(--focus-ring);background:#fff}.layers-filters{border-bottom:1px solid #0000000f;gap:6px;padding:12px 16px;display:flex}.filter-btn{border-radius:var(--radius-md);text-transform:capitalize;cursor:pointer;color:var(--text-secondary);background:#ffffff80;border:1px solid #0000001a;flex:1;padding:6px 12px;font-size:11px;font-weight:600;transition:all .2s}.filter-btn:hover{border-color:rgba(var(--color-primary-rgb), .3);background:#fffc}.filter-btn.active{background:linear-gradient(135deg, var(--color-primary), #8b5cf6);color:#fff;border-color:#0000}.layers-list{flex:1;padding:8px;overflow:visible auto}.layers-list::-webkit-scrollbar{width:6px}.layers-list::-webkit-scrollbar-thumb{background:#0003;border-radius:3px}.layers-empty{text-align:center;color:#9ca3af;padding:40px 20px}.layers-empty p{margin:0 0 8px;font-size:14px;font-weight:600}.layers-empty small{font-size:12px}.layer-item{border-radius:var(--radius-lg);cursor:pointer;background:#ffffff80;border:1px solid #0000;justify-content:space-between;align-items:center;margin-bottom:4px;padding:10px 12px;transition:all .2s;display:flex;position:relative;overflow:visible}.layer-item:hover{border-color:rgba(var(--color-primary-rgb), .2);background:#fffc;transform:translate(2px)}.layer-item.selected{background:rgba(var(--color-primary-rgb), .1);border-color:var(--color-primary);box-shadow:0 2px 8px rgba(var(--color-primary-rgb), .15)}.layer-item.dragging{opacity:.5;cursor:grabbing;transform:scale(.98);box-shadow:0 4px 12px #00000026}.layer-item.drag-over{border-top:3px solid var(--color-primary);background:rgba(var(--color-primary-rgb), .05);box-shadow:0 -2px 8px rgba(var(--color-primary-rgb), .2);margin-top:8px}.layer-item-content{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.layer-drag-handle{color:#9ca3af;cursor:grab;-webkit-user-select:none;user-select:none;opacity:.6;border-radius:var(--radius-xs);background:0 0;flex-shrink:0;margin-right:4px;padding:4px 6px;font-size:16px;transition:all .2s}.layer-drag-handle:hover{opacity:1;color:var(--color-primary);background:rgba(var(--color-primary-rgb), .1);transform:scale(1.15)}.layer-drag-handle:active,.layer-item.dragging .layer-drag-handle{cursor:grabbing;opacity:1;background:rgba(var(--color-primary-rgb), .15)}.layer-icon{flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:18px;display:flex}.layer-info{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.layer-label{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;overflow:hidden}.layer-meta{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.layer-actions{opacity:1;flex-shrink:0;gap:4px;padding:4px 0 4px 8px;transition:opacity .2s;display:flex}.layer-item:not(:hover) .layer-actions{opacity:.7}.layer-item:hover .layer-actions{opacity:1}.layer-actions:has(.layer-action-btn.active){opacity:1!important}.layer-action-btn{border-radius:var(--radius-sm);cursor:pointer;width:24px;height:24px;color:var(--text-secondary);pointer-events:auto;z-index:5;background:#0000000a;border:none;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;transition:all .2s;display:flex;position:relative}.layer-action-btn:hover{color:var(--text-primary);background:#00000014;transform:scale(1.05)}.layer-action-btn.danger{z-index:10;position:relative}.layer-action-btn.danger:hover{background:rgba(var(--color-danger-rgb), .1);color:var(--color-danger);transform:scale(1.05)}.layer-action-btn.active{background:rgba(var(--color-primary-rgb), .1);color:var(--color-primary)}.layer-action-btn.active:hover{background:rgba(var(--color-primary-rgb), .2);color:var(--color-primary-dark)}.layer-action-btn.visibility-toggle.hidden{color:#f97316;background:#f973161a}.layer-action-btn.visibility-toggle.hidden:hover{color:#ea580c;background:#f9731633}.layer-action-btn.lock-toggle.locked{color:#f59e0b;background:#fbbf2426}.layer-action-btn.lock-toggle.locked:hover{color:#d97706;background:#fbbf2440}.layer-name-input{border:1px solid var(--color-primary);border-radius:var(--radius-sm);color:var(--text-primary);box-shadow:var(--focus-ring);background:#fff;outline:none;flex:1;padding:4px 8px;font-family:inherit;font-size:13px;font-weight:500}.layer-item.invisible{opacity:.5}.layer-item.invisible .layer-label{color:#9ca3af;text-decoration:line-through}.layer-item.invisible .layer-icon{opacity:.4}.layer-item.locked{background:#fbbf240d}.layer-item.locked .layer-drag-handle{cursor:not-allowed;opacity:.4}.item-locked-indicator{pointer-events:none;z-index:12;background:#fbbf24f2;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:flex;position:absolute;top:4px;right:4px;box-shadow:0 4px 12px #fbbf2466}.item-edit-button{background:rgba(var(--color-primary-rgb), .95);color:#fff;letter-spacing:.5px;text-transform:capitalize;cursor:pointer;box-shadow:0 4px 12px rgba(var(--color-primary-rgb), .4);z-index:12;-webkit-user-select:none;user-select:none;border:2px solid #fff;border-radius:999px;padding:6px 14px;font-size:11px;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);position:absolute;bottom:4px;left:50%;transform:translate(-50%)}.item-edit-button:hover{box-shadow:0 6px 16px rgba(var(--color-primary-rgb), .5);background:rgba(var(--color-primary-rgb), 1);transform:translate(-50%)scale(1.05)}.item-edit-button:active{transform:translate(-50%)scale(.95)}.item-text-input{border:2px solid var(--color-primary);border-radius:var(--radius-md);width:100%;color:var(--text-primary);box-shadow:var(--focus-ring);background:#fff;outline:none;padding:8px 12px;font-family:inherit;font-size:14px}.item-text-input:focus{box-shadow:0 0 0 3px rgba(var(--color-primary-rgb), .2)}.properties-panel{--xr-background-material:thin;flex-direction:column;height:100%;display:flex;overflow:hidden}.properties-header{border-bottom:1px solid #0000000f;justify-content:space-between;align-items:center;padding:20px;display:flex}.properties-title{color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;margin:0;font-size:16px;font-weight:700}.item-type-badge{background:rgba(var(--color-primary-rgb), .1);color:var(--color-primary);border-radius:var(--radius-xl);text-transform:uppercase;padding:4px 10px;font-size:11px;font-weight:600}.properties-content{flex:1;padding:16px;overflow-y:auto}.properties-content::-webkit-scrollbar{width:6px}.properties-content::-webkit-scrollbar-thumb{background:#0003;border-radius:3px}.properties-empty{text-align:center;color:#9ca3af;flex-direction:column;justify-content:center;align-items:center;height:100%;padding:40px 20px;display:flex}.empty-icon{margin-bottom:16px;font-size:48px}.properties-empty h3{color:var(--text-secondary);margin:0 0 8px;font-size:16px;font-weight:600}.properties-empty p{margin:0;font-size:13px}.property-section{margin-bottom:24px}.property-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;font-size:12px;font-weight:600;display:block}.property-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.property-input-group{flex-direction:column;gap:6px;display:flex}.property-input-group label{color:#9ca3af;text-transform:uppercase;letter-spacing:.3px;font-size:11px;font-weight:600}.property-input{border-radius:var(--radius-md);width:100%;font-size:13px;font-family:var(--font-mono);background:#fffc;border:1px solid #0000001a;outline:none;padding:10px 12px;transition:all .2s}.property-input:focus{border-color:var(--color-primary);box-shadow:var(--focus-ring);background:#fff}.depth-quick-buttons{grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:12px;display:grid}.depth-btn{border-radius:var(--radius-md);cursor:pointer;color:var(--text-secondary);background:#ffffff80;border:1px solid #0000001a;padding:8px;font-size:12px;font-weight:600;transition:all .2s}.depth-btn:hover{border-color:rgba(var(--color-primary-rgb), .3);background:#fffc}.depth-btn.active{background:linear-gradient(135deg, var(--color-primary), #8b5cf6);color:#fff;box-shadow:0 2px 8px rgba(var(--color-primary-rgb), .3);border-color:#0000}.depth-slider-alt{appearance:none;background:linear-gradient(90deg, #e5e7eb 0%, var(--color-primary) 100%);cursor:pointer;border-radius:3px;outline:none;width:100%;height:6px}.depth-slider-alt::-webkit-slider-thumb{appearance:none;background:var(--color-primary);cursor:pointer;border:2px solid #fff;border-radius:50%;width:18px;height:18px;box-shadow:0 2px 6px #0003}.depth-slider-alt::-moz-range-thumb{background:var(--color-primary);cursor:pointer;border:2px solid #fff;border-radius:50%;width:18px;height:18px;box-shadow:0 2px 6px #0003}.color-picker-wrapper{align-items:center;gap:10px;display:flex}.color-picker-input{border-radius:var(--radius-md);cursor:pointer;appearance:none;background:0 0;border:1px solid #0000001a;width:60px;height:44px}.color-picker-input::-webkit-color-swatch-wrapper{padding:4px}.color-picker-input::-webkit-color-swatch{border-radius:var(--radius-sm);border:none}.color-picker-input::-moz-color-swatch{border-radius:var(--radius-sm);border:none}.color-text-input{border-radius:var(--radius-md);font-size:13px;font-family:var(--font-mono);background:#fffc;border:1px solid #0000001a;outline:none;flex:1;padding:10px 12px;transition:all .2s}.color-text-input:focus{border-color:var(--color-primary);box-shadow:var(--focus-ring);background:#fff}.text-content-input{border-radius:var(--radius-md);resize:vertical;background:#fffc;border:1px solid #0000001a;outline:none;width:100%;padding:10px 12px;font-family:inherit;font-size:13px;transition:all .2s}.text-content-input:focus{border-color:var(--color-primary);box-shadow:var(--focus-ring);background:#fff}.layer-order-btn{border-radius:var(--radius-md);cursor:pointer;width:100%;color:var(--text-secondary);background:#ffffff80;border:1px solid #0000001a;padding:10px;font-size:12px;font-weight:600;transition:all .2s}.layer-order-btn:hover{background:rgba(var(--color-primary-rgb), .1);border-color:rgba(var(--color-primary-rgb), .3);color:var(--color-primary)}.depth-slider-wrapper{border-top:1px solid #0000000f;padding:16px}.command-palette-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999;background:#00000080;justify-content:center;align-items:flex-start;padding-top:100px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.command-palette{border-radius:var(--radius-2xl);--xr-background-material:thick;background:#fffffffa;width:600px;max-width:90vw;animation:.2s cubic-bezier(.4,0,.2,1) slideDown;overflow:hidden;box-shadow:0 20px 60px #0000004d,0 8px 24px #0003}html.is-spatial .command-palette{-webkit-backdrop-filter:blur(40px);backdrop-filter:blur(40px);background:#fff6}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.command-search{border-bottom:1px solid #00000014;align-items:center;gap:12px;padding:20px;display:flex}.command-search-icon{color:var(--text-secondary);font-size:20px}.command-search-input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;font-size:16px;font-weight:500}.command-search-input::placeholder{color:#9ca3af}.command-list{max-height:400px;padding:8px;overflow-y:auto}.command-list::-webkit-scrollbar{width:8px}.command-list::-webkit-scrollbar-thumb{border-radius:var(--radius-xs);background:#0003}.command-empty{text-align:center;color:#9ca3af;padding:40px 20px}.command-empty p{margin:0 0 8px;font-size:14px;font-weight:600}.command-empty small{font-size:12px}.command-item{border-radius:var(--radius-lg);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:14px;width:100%;padding:12px 16px;transition:all .15s;display:flex}.command-item:hover,.command-item.selected{background:rgba(var(--color-primary-rgb), .1)}.command-icon{background:rgba(var(--color-primary-rgb), .1);border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;display:flex}.command-item.selected .command-icon{background:rgba(var(--color-primary-rgb), .2)}.command-info{flex-direction:column;flex:1;gap:4px;display:flex}.command-label{color:var(--text-primary);font-size:14px;font-weight:600}.command-description{color:var(--text-secondary);font-size:12px}.command-footer{background:#00000005;border-top:1px solid #00000014;padding:12px 20px}.command-hint{color:var(--text-secondary);align-items:center;gap:12px;font-size:11px;display:flex}.command-hint kbd{border-radius:var(--radius-xs);font-size:11px;font-weight:600;font-family:var(--font-mono);background:#0000000d;border:1px solid #0000001a;padding:2px 6px}.context-menu{border-radius:var(--radius-xl);z-index:1001;--xr-background-material:thick;background:#fffffffa;min-width:220px;padding:6px;animation:.15s contextMenuFadeIn;position:fixed;box-shadow:0 12px 40px #0003,0 4px 12px #0000001a}html.is-spatial .context-menu{-webkit-backdrop-filter:blur(40px);backdrop-filter:blur(40px);background:#fff6}@keyframes contextMenuFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.context-menu-item{border-radius:var(--radius-md);cursor:pointer;text-align:left;width:100%;color:var(--text-primary);background:0 0;border:none;align-items:center;gap:12px;padding:10px 12px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.context-menu-item:hover:not(.disabled){background:rgba(var(--color-primary-rgb), .1)}.context-menu-item.disabled{opacity:.4;cursor:not-allowed}.context-menu-icon{justify-content:center;align-items:center;width:20px;height:20px;font-size:16px;display:flex}.context-menu-label{flex:1}.context-menu-separator{background:#00000014;height:1px;margin:4px 8px}.minimap-container{--xr-background-material:thin;border-bottom:1px solid #0000000f;padding:12px}.minimap-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.minimap-title{color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;margin:0;font-size:11px;font-weight:700}.minimap-zoom-badge{color:var(--color-primary);background:rgba(var(--color-primary-rgb), .08);border-radius:var(--radius-md);padding:2px 8px;font-size:10px;font-weight:700}.minimap-canvas-wrapper{border-radius:var(--radius-md);border:1.5px solid #00000014;transition:border-color .2s;overflow:hidden;box-shadow:0 1px 4px #0000000a}.minimap-canvas-wrapper:hover{border-color:rgba(var(--color-primary-rgb), .25)}.minimap-canvas{background:#f8fafc;display:block}.minimap-controls{justify-content:center;align-items:center;gap:4px;margin-top:8px;display:flex}.minimap-ctrl-btn{border-radius:var(--radius-sm);width:28px;height:24px;color:var(--text-body);cursor:pointer;background:#0000000a;border:1px solid #0000000f;justify-content:center;align-items:center;font-size:13px;font-weight:600;transition:all .15s;display:flex}.minimap-ctrl-btn:hover{background:rgba(var(--color-primary-rgb), .1);border-color:rgba(var(--color-primary-rgb), .2);color:var(--color-primary)}.minimap-ctrl-fit{text-transform:uppercase;letter-spacing:.3px;width:auto;padding:0 10px;font-size:10px}.minimap-depth-legend{border-top:1px solid #0000000a;gap:6px;margin-top:8px;padding-top:8px;display:flex}.minimap-depth-row{opacity:.35;align-items:center;gap:3px;transition:opacity .2s;display:flex}.minimap-depth-row.active{opacity:1}.minimap-depth-swatch{border-radius:2px;width:8px;height:8px}.minimap-depth-label{color:var(--text-secondary);font-size:9px;font-weight:600}.minimap-depth-count{color:var(--text-body);text-align:center;min-width:10px;font-size:9px;font-weight:700}.board-scene-container{width:100%;height:100vh;position:relative;overflow:visible}.board-scene-container .board{width:100%;height:100%}.layers-scene{background:#f8fafcfa;width:100%;height:100vh;overflow:hidden}html.is-spatial .layers-scene{background:0 0}.layers-scene .layers-panel{border:none;height:100%}.controls-scene{background:#f8fafcfa;width:100%;height:100vh;overflow:hidden}html.is-spatial .controls-scene{background:0 0}.controls-container{flex-direction:column;height:100%;display:flex;overflow:hidden}.controls-container>*{border:none}.controls-container .minimap-container{flex-shrink:0}.controls-container .properties-panel{flex:1;overflow-y:auto}.controls-container .depth-slider-wrapper{flex-shrink:0}.help-scene{background:#f8fafcfa;width:100%;height:100vh;padding:0;overflow-y:auto}html.is-spatial .help-scene{background:0 0}.help-container{flex-direction:column;max-width:100%;height:100%;display:flex}.help-header{border-bottom:2px solid rgba(var(--color-primary-rgb), .2);background:linear-gradient(135deg, rgba(var(--color-primary-rgb), .05), #8b5cf60d);flex-shrink:0;padding:24px 24px 16px}.help-title{color:var(--text-primary);background:linear-gradient(135deg, var(--color-primary), #8b5cf6);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0;font-size:28px;font-weight:800}.help-subtitle{color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;margin:4px 0 0;font-size:13px;font-weight:600}.help-content{flex:1;padding:16px 24px 24px;overflow-y:auto}.help-content::-webkit-scrollbar{width:8px}.help-content::-webkit-scrollbar-thumb{background:rgba(var(--color-primary-rgb), .3);border-radius:var(--radius-xs)}.help-content::-webkit-scrollbar-thumb:hover{background:rgba(var(--color-primary-rgb), .5)}.help-section{margin-bottom:28px}.help-section:last-child{margin-bottom:0}.help-section-title{color:var(--text-primary);border-bottom:1px solid #00000014;align-items:center;gap:8px;margin:0 0 14px;padding-bottom:8px;font-size:16px;font-weight:700;display:flex}.help-items{flex-direction:column;gap:8px;display:flex}.help-item{border-radius:var(--radius-md);background:#fff9;border:1px solid #0000000f;justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;transition:all .2s;display:flex}html.is-spatial .help-item{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff4d}.help-item:hover{background:rgba(var(--color-primary-rgb), .08);border-color:rgba(var(--color-primary-rgb), .2);transform:translate(2px)}.help-item kbd{border-radius:var(--radius-xs);font-size:11px;font-weight:700;font-family:var(--font-mono);color:var(--text-body);white-space:nowrap;background:#0000000f;border:1px solid #00000026;padding:4px 8px;box-shadow:0 1px 2px #0000001a}.help-item strong{color:var(--text-primary);min-width:140px;font-size:13px;font-weight:700}.help-item span{color:var(--text-secondary);text-align:right;flex:1;font-size:13px}.help-text{color:var(--color-primary);box-shadow:none;background:0 0;border:none;padding:0;font-weight:600}.help-icon{background:linear-gradient(135deg, var(--color-primary), #8b5cf6);color:#fff;border-radius:var(--radius-md);width:32px;height:32px;box-shadow:0 2px 6px rgba(var(--color-primary-rgb), .3);flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:700;display:inline-flex}.help-tips{background:rgba(var(--color-primary-rgb), .05);border-radius:var(--radius-md);border:1px solid rgba(var(--color-primary-rgb), .15);flex-direction:column;gap:10px;padding:14px;display:flex}.help-tips p{color:#4b5563;margin:0;font-size:13px;line-height:1.6}.help-tips p strong{color:var(--text-primary);font-weight:600}.export-scene{background:#f8fafcfa;flex-direction:column;width:100%;height:100vh;display:flex;overflow:hidden}html.is-spatial .export-scene{background:0 0}.export-scene-header{border-bottom:1px solid #00000014;flex-shrink:0;justify-content:space-between;align-items:center;padding:20px;display:flex}.export-scene-title{color:var(--text-primary);margin:0;font-size:18px;font-weight:700}.export-scene-close{border-radius:var(--radius-md);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;background:#0000000d;border:none;justify-content:center;align-items:center;font-size:24px;transition:all .2s;display:flex}.export-scene-close:hover{color:var(--text-primary);background:#0000001a}.export-scene-content{flex-direction:column;flex:1;padding:16px 20px;display:flex;overflow:hidden}.export-scene-textarea{border-radius:var(--radius-md);width:100%;font-family:var(--font-mono);resize:none;color:var(--text-body);background:#fffc;border:1px solid #0000001a;flex:1;padding:12px;font-size:11px;line-height:1.5}.export-scene-textarea:focus{border-color:var(--color-primary);box-shadow:var(--focus-ring);outline:none}.export-scene-actions{flex-shrink:0;gap:12px;padding:16px 20px;display:flex}.export-scene-button{border-radius:var(--radius-lg);cursor:pointer;border:none;flex:1;padding:12px 20px;font-size:14px;font-weight:600;transition:all .2s}.export-scene-button-primary{background:linear-gradient(135deg, var(--color-primary), #8b5cf6);color:#fff;box-shadow:0 2px 8px rgba(var(--color-primary-rgb), .3)}.export-scene-button-primary:hover{box-shadow:0 4px 16px rgba(var(--color-primary-rgb), .4);background:linear-gradient(135deg,#7c3aed,#a855f7);transform:translateY(-1px)}.export-scene-button-secondary{color:var(--text-body);background:#0000000d}.export-scene-button-secondary:hover{background:#0000001a}.export-scene-hint{color:var(--text-primary);text-align:center;border-radius:var(--radius-md);background:#fff9;flex-shrink:0;margin:0 20px 16px;padding:12px 20px 16px;font-size:13px}html.is-spatial .export-scene-hint{color:var(--text-primary);background:#ffffff4d}.import-scene{background:#f8fafcfa;flex-direction:column;width:100%;height:100vh;display:flex;overflow:hidden}html.is-spatial .import-scene{background:0 0}.import-scene-header{border-bottom:1px solid #00000014;flex-shrink:0;justify-content:space-between;align-items:center;padding:20px;display:flex}.import-scene-title{color:var(--text-primary);margin:0;font-size:18px;font-weight:700}.import-scene-close{border-radius:var(--radius-md);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;background:#0000000d;border:none;justify-content:center;align-items:center;font-size:24px;transition:all .2s;display:flex}.import-scene-close:hover{color:var(--text-primary);background:#0000001a}.import-scene-file-section{border-bottom:1px solid #00000014;flex-direction:column;align-items:center;gap:8px;padding:16px 20px;display:flex}.import-scene-button-file{color:#fff;background:linear-gradient(135deg,#10b981,#059669);width:100%;padding:14px 20px;box-shadow:0 2px 8px #10b9814d}.import-scene-button-file:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 4px 16px #10b98166}.import-scene-or{color:var(--text-secondary);font-size:12px;font-weight:500}.import-scene-content{flex-direction:column;flex:1;padding:16px 20px;display:flex;overflow:hidden}.import-scene-textarea{border-radius:var(--radius-md);width:100%;font-family:var(--font-mono);resize:none;color:var(--text-body);background:#fffc;border:1px solid #0000001a;flex:1;padding:12px;font-size:11px;line-height:1.5}.import-scene-textarea:focus{border-color:var(--color-primary);box-shadow:var(--focus-ring);outline:none}.import-scene-textarea.has-error{border-color:var(--color-danger);box-shadow:0 0 0 3px rgba(var(--color-danger-rgb), .1)}.import-scene-textarea::placeholder{color:#9ca3af}.import-scene-error{background:rgba(var(--color-danger-rgb), .1);border:1px solid rgba(var(--color-danger-rgb), .3);border-radius:var(--radius-md);color:#dc2626;margin:0 20px;padding:10px 20px;font-size:13px;font-weight:500}.import-scene-actions{flex-shrink:0;gap:12px;padding:16px 20px;display:flex}.import-scene-button{border-radius:var(--radius-lg);cursor:pointer;border:none;flex:1;padding:12px 20px;font-size:14px;font-weight:600;transition:all .2s}.import-scene-button:disabled{opacity:.5;cursor:not-allowed}.import-scene-button-primary{background:linear-gradient(135deg, var(--color-primary), #8b5cf6);color:#fff;box-shadow:0 2px 8px rgba(var(--color-primary-rgb), .3)}.import-scene-button-primary:hover:not(:disabled){box-shadow:0 4px 16px rgba(var(--color-primary-rgb), .4);background:linear-gradient(135deg,#7c3aed,#a855f7);transform:translateY(-1px)}.import-scene-button-secondary{color:var(--text-body);background:#0000000d}.import-scene-button-secondary:hover:not(:disabled){background:#0000001a}.import-scene-hint{color:var(--text-primary);text-align:center;border-radius:var(--radius-md);background:#fff9;flex-shrink:0;margin:0 20px 16px;padding:12px 20px 16px;font-size:13px}html.is-spatial .import-scene-hint{color:var(--text-primary);background:#ffffff4d}.welcome-popup-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;--xr-back:120;--xr-z-index:500;opacity:0;background:#0009;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:fixed;inset:0}.welcome-popup-overlay.visible{opacity:1}.welcome-popup{opacity:0;--xr-background-material:thick;background:#fffffffa;border-radius:24px;width:420px;max-width:90vw;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden;transform:translateY(20px)scale(.95);box-shadow:0 24px 80px #0000004d,0 8px 32px #0003}.welcome-popup.visible{opacity:1;transform:translateY(0)scale(1)}html.is-spatial .welcome-popup{-webkit-backdrop-filter:none;backdrop-filter:none;--xr-background-material:thick;background:#fff}html.is-spatial .welcome-tip-title{font-size:18px}html.is-spatial .welcome-tip-desc{color:var(--text-body);font-size:15px}html.is-spatial .welcome-popup-content{padding:28px 36px}.welcome-popup-header{background:linear-gradient(135deg, var(--color-primary), #8b5cf6);text-align:center;padding:32px 32px 24px}.welcome-popup-title{color:#fff;text-shadow:0 2px 4px #0000001a;margin:0;font-size:24px;font-weight:800}.welcome-popup-subtitle{color:#ffffffd9;margin:8px 0 0;font-size:14px;font-weight:500}.welcome-popup-content{padding:24px 32px}.welcome-step-dots{justify-content:center;gap:8px;margin-bottom:24px;display:flex}.welcome-step-dot{cursor:pointer;background:#00000026;border:none;border-radius:50%;width:8px;height:8px;padding:0;transition:all .2s}.welcome-step-dot.active{background:var(--color-primary);transform:scale(1.3)}.welcome-step-dot.completed{background:#a5b4fc}.welcome-tip-card{text-align:center;background:rgba(var(--color-primary-rgb), .08);border-radius:var(--radius-2xl);border:1px solid rgba(var(--color-primary-rgb), .12);flex-direction:column;align-items:center;gap:12px;min-height:140px;padding:20px 16px;display:flex}html.is-spatial .welcome-tip-card{background:rgba(var(--color-primary-rgb), .1);border:1px solid rgba(var(--color-primary-rgb), .2)}.welcome-tip-icon{font-size:36px}.welcome-tip-title{color:var(--text-primary);font-size:16px;font-weight:700}.welcome-tip-desc{color:var(--text-secondary);margin:0;font-size:13px;line-height:1.5}.welcome-popup-intro{color:var(--text-secondary);text-align:center;margin:0 0 20px;font-size:14px}.welcome-popup-features{flex-direction:column;gap:16px;display:flex}.welcome-popup-feature{background:rgba(var(--color-primary-rgb), .06);border-radius:var(--radius-xl);border:1px solid rgba(var(--color-primary-rgb), .1);align-items:center;gap:16px;padding:14px 16px;transition:all .2s;display:flex}.welcome-popup-feature:hover{background:rgba(var(--color-primary-rgb), .1);border-color:rgba(var(--color-primary-rgb), .2);transform:translate(4px)}.welcome-popup-feature-icon{background:linear-gradient(135deg, var(--color-primary), #8b5cf6);border-radius:var(--radius-xl);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:28px;display:flex}.welcome-popup-feature-info{flex-direction:column;gap:4px;display:flex}.welcome-popup-feature-info strong{color:var(--text-primary);font-size:15px;font-weight:700}.welcome-popup-feature-info span{color:var(--text-secondary);font-size:13px}.welcome-popup-footer{background:#00000005;border-top:1px solid #0000000f;justify-content:space-between;align-items:center;gap:16px;padding:20px 32px 28px;display:flex}.welcome-popup-actions{align-items:center;gap:10px;display:flex}.welcome-popup-skip{color:#9ca3af;cursor:pointer;background:0 0;border:none;padding:10px 16px;font-size:13px;font-weight:500;transition:color .15s}.welcome-popup-skip:hover{color:var(--text-secondary)}.welcome-popup-checkbox{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;display:flex}.welcome-popup-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary);cursor:pointer}.welcome-popup-checkbox span{color:var(--text-secondary);font-size:13px}.welcome-popup-button{background:linear-gradient(135deg, var(--color-primary), #8b5cf6);color:#fff;border-radius:var(--radius-lg);cursor:pointer;box-shadow:0 4px 16px rgba(var(--color-primary-rgb), .3);border:none;padding:10px 20px;font-size:14px;font-weight:700;transition:all .2s}.welcome-popup-button:hover{box-shadow:0 6px 24px rgba(var(--color-primary-rgb), .4);background:linear-gradient(135deg,#7c3aed,#a855f7);transform:translateY(-2px)}.welcome-popup-button:active{transform:translateY(0)}.toolbar-hints-container{pointer-events:none;z-index:1500;width:100%;height:100%;position:fixed;top:0;left:0}.toolbar-hint{background:linear-gradient(135deg, var(--color-primary), #8b5cf6);color:#fff;box-shadow:0 4px 20px rgba(var(--color-primary-rgb), .4);opacity:0;white-space:nowrap;--xr-background-material:thick;border-radius:999px;align-items:center;gap:8px;padding:10px 16px;font-size:13px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;transform:translateY(-50%)translate(-10px)}.toolbar-hint.visible{opacity:1;transform:translateY(-50%)translate(0)}.toolbar-hint.fading-out{opacity:0;transform:translateY(-50%)translate(10px)}.toolbar-hint-arrow{border-top:6px solid #0000;border-bottom:6px solid #0000;border-right:6px solid var(--color-primary);width:0;height:0;position:absolute;top:50%;left:-6px;transform:translateY(-50%)}.toolbar-hint-icon{font-size:16px}.toolbar-hint-label{font-weight:600}html.is-spatial .toolbar-hint{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.startup-hints-overlay{z-index:2000;opacity:0;cursor:pointer;background:0 0;justify-content:center;align-items:center;transition:opacity .4s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;inset:0}html:not(.is-spatial) .startup-hints-overlay{background:#0000004d}.startup-hints-overlay.visible{opacity:1}.startup-hints-overlay.fading-out{opacity:0}.startup-hints-card{background:linear-gradient(135deg, rgba(var(--color-primary-rgb), .98), #8b5cf6fa);box-shadow:0 12px 48px rgba(var(--color-primary-rgb), .5);color:#fff;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);cursor:default;border-radius:20px;max-width:320px;padding:28px 32px;transition:transform .4s cubic-bezier(.4,0,.2,1);position:relative;transform:scale(.95)}.startup-hints-overlay.visible .startup-hints-card{transform:scale(1)}.startup-hints-overlay.fading-out .startup-hints-card{transform:scale(.95)}.startup-hints-close{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:18px;transition:background .2s;display:flex;position:absolute;top:12px;right:12px}.startup-hints-close:hover{background:#ffffff4d}.startup-hints-title{margin-bottom:6px;font-size:18px;font-weight:700}.startup-hints-subtitle{opacity:.8;margin-bottom:20px;font-size:13px}.startup-hints-items{flex-direction:column;gap:10px;display:flex}.startup-hint-item{border-radius:var(--radius-xl);background:#ffffff26;align-items:center;gap:14px;padding:12px 16px;display:flex}.startup-hint-icon{text-align:center;width:28px;font-size:20px}.startup-hint-text{flex-direction:column;gap:2px;display:flex}.startup-hint-label{font-size:14px;font-weight:600}.startup-hint-desc{opacity:.75;font-size:12px}.startup-hints-footer{text-align:center;opacity:.6;margin-top:20px;font-size:12px}.welcome-scene{background:linear-gradient(135deg, rgba(var(--color-primary-rgb), .95), #8b5cf6f2);box-sizing:border-box;color:#fff;flex-direction:column;justify-content:center;width:100%;height:100vh;padding:32px;display:flex}html.is-spatial .welcome-scene{--xr-background-material:thick;background:0 0}.welcome-title{text-align:center;margin:0 0 12px;font-size:clamp(20px,5vw,28px);font-weight:700}.welcome-subtitle{opacity:.85;text-align:center;margin:0 0 24px;font-size:clamp(13px,3vw,16px);line-height:1.5}.welcome-panels{flex-direction:column;flex:1;justify-content:center;gap:12px;max-height:300px;margin-bottom:32px;display:flex}.welcome-panel-item{text-align:left;background:#ffffff26;border-radius:14px;align-items:center;gap:16px;padding:16px 20px;display:flex}.welcome-panel-icon{text-align:center;flex-shrink:0;width:36px;font-size:clamp(20px,4vw,28px)}.welcome-panel-text{flex-direction:column;gap:4px;display:flex}.welcome-panel-text strong{font-size:clamp(14px,3vw,18px);font-weight:600}.welcome-panel-text span{opacity:.75;font-size:clamp(12px,2.5vw,14px)}.welcome-dismiss-btn{width:100%;color:var(--color-primary);cursor:pointer;background:#fffffff2;border:none;border-radius:14px;flex-shrink:0;padding:16px 24px;font-size:clamp(15px,3vw,18px);font-weight:700;transition:all .2s}.welcome-dismiss-btn:hover{background:#fff;transform:scale(1.02)}.clear-scene{height:100vh;font-family:var(--font-sans);background:linear-gradient(135deg,#f8fafc,#e2e8f0);flex-direction:column;display:flex}html.is-spatial .clear-scene{--xr-background-material:thick;background:0 0}.clear-scene-header{border-bottom:1px solid #00000014;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}html.is-spatial .clear-scene-header{border-bottom-color:#ffffff1a}.clear-scene-title{color:#1e293b;margin:0;font-size:20px;font-weight:700}html.is-spatial .clear-scene-title{color:#fff}.clear-scene-close{color:#64748b;cursor:pointer;background:#0000000f;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:20px;transition:all .2s;display:flex}html.is-spatial .clear-scene-close{color:#fff;background:#ffffff26}.clear-scene-close:hover{background:#0000001f}html.is-spatial .clear-scene-close:hover{background:#ffffff40}.clear-scene-content{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:24px;display:flex}.clear-scene-message{color:#1e293b;margin:0 0 8px;font-size:16px;font-weight:500}html.is-spatial .clear-scene-message{color:#fff}.clear-scene-submessage{color:#64748b;margin:0;font-size:14px}html.is-spatial .clear-scene-submessage{color:#ffffffb3}.clear-scene-success{flex-direction:column;align-items:center;gap:12px;display:flex}.clear-scene-success-icon{color:#fff;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;display:flex}.clear-scene-success p{color:#10b981;margin:0;font-size:16px;font-weight:600}html.is-spatial .clear-scene-success p{color:#34d399}.clear-scene-actions{border-top:1px solid #00000014;flex-direction:column;gap:10px;padding:20px;display:flex}html.is-spatial .clear-scene-actions{border-top-color:#ffffff1a}.clear-scene-btn{border-radius:var(--radius-xl);cursor:pointer;border:none;padding:14px 20px;font-size:15px;font-weight:600;transition:all .2s}.clear-scene-btn:disabled{opacity:.5;cursor:not-allowed}.clear-scene-btn-primary{background:linear-gradient(135deg, var(--color-primary), #8b5cf6);color:#fff}.clear-scene-btn-primary:hover:not(:disabled){box-shadow:0 4px 16px rgba(var(--color-primary-rgb), .4);transform:scale(1.02)}.clear-scene-btn-danger{background:var(--color-danger);color:#fff}.clear-scene-btn-danger:hover:not(:disabled){background:#dc2626;transform:scale(1.02)}.clear-scene-btn-secondary{color:#64748b;background:#00000014}html.is-spatial .clear-scene-btn-secondary{color:#fff;background:#ffffff26}.clear-scene-btn-secondary:hover:not(:disabled){background:#0000001f}html.is-spatial .clear-scene-btn-secondary:hover:not(:disabled){background:#ffffff40}.grid-align-scene{height:100vh;font-family:var(--font-sans);background:linear-gradient(135deg,#f8fafc,#e2e8f0);flex-direction:column;display:flex}html.is-spatial .grid-align-scene{--xr-background-material:thick;background:0 0}.grid-align-scene-header{border-bottom:1px solid #00000014;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}html.is-spatial .grid-align-scene-header{border-bottom-color:#ffffff1a}.grid-align-scene-title{color:#1e293b;margin:0;font-size:20px;font-weight:700}html.is-spatial .grid-align-scene-title{color:#fff}.grid-align-scene-close{color:#64748b;cursor:pointer;background:#0000000f;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:20px;transition:background .2s;display:flex}html.is-spatial .grid-align-scene-close{color:#fff;background:#ffffff26}.grid-align-scene-close:hover{background:#0000001f}html.is-spatial .grid-align-scene-close:hover{background:#ffffff40}.grid-align-scene-content{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:20px;display:flex}.grid-align-scene-message{color:#1e293b;margin:0 0 16px;font-size:16px;font-weight:500}html.is-spatial .grid-align-scene-message{color:#fff}.grid-align-scene-breakdown{background:rgba(var(--color-primary-rgb), .1);border-radius:var(--radius-xl);flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:16px;padding:16px;display:flex}html.is-spatial .grid-align-scene-breakdown{background:#ffffff1a}.grid-align-scene-item-type{color:#475569;align-items:center;gap:6px;font-size:14px;display:flex}html.is-spatial .grid-align-scene-item-type{color:#ffffffe6}.grid-align-scene-item-icon{font-size:16px}.grid-align-scene-warning{color:#f59e0b;margin:0;font-size:13px}html.is-spatial .grid-align-scene-warning{color:#fbbf24}.grid-align-scene-success{flex-direction:column;align-items:center;gap:12px;display:flex}.grid-align-scene-success-icon{color:#fff;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;display:flex}.grid-align-scene-success p{color:#10b981;margin:0;font-size:16px;font-weight:600}html.is-spatial .grid-align-scene-success p{color:#34d399}.grid-align-scene-actions{border-top:1px solid #00000014;gap:12px;padding:20px;display:flex}html.is-spatial .grid-align-scene-actions{border-top-color:#ffffff1a}.grid-align-scene-btn{border-radius:var(--radius-xl);cursor:pointer;border:none;flex:1;padding:14px 20px;font-size:15px;font-weight:600;transition:transform .2s,box-shadow .2s}.grid-align-scene-btn:disabled{opacity:.5;cursor:not-allowed}.grid-align-scene-btn-primary{background:linear-gradient(135deg, var(--color-primary), #8b5cf6);color:#fff}.grid-align-scene-btn-primary:hover:not(:disabled){box-shadow:0 4px 16px rgba(var(--color-primary-rgb), .4);transform:scale(1.02)}.grid-align-scene-btn-secondary{color:#64748b;background:#00000014}html.is-spatial .grid-align-scene-btn-secondary{color:#fff;background:#ffffff26}.grid-align-scene-btn-secondary:hover:not(:disabled){background:#0000001f}html.is-spatial .grid-align-scene-btn-secondary:hover:not(:disabled){background:#ffffff40}.remote-cursors-layer{pointer-events:none;z-index:9999;position:fixed;inset:0;overflow:visible}.remote-cursor{pointer-events:none;transition:left 80ms linear,top 80ms linear;position:absolute}.remote-cursor-label{color:#fff;border-radius:var(--radius-xs);white-space:nowrap;pointer-events:none;padding:2px 6px;font-size:11px;font-weight:600;position:absolute;top:20px;left:12px}.collab-panel{-webkit-backdrop-filter:blur(40px);backdrop-filter:blur(40px);border-radius:var(--radius-2xl);width:280px;box-shadow:var(--shadow-lg);z-index:2000;--xr-background-material:thick;background:#fffffffa;border:1px solid #fff9;position:absolute;top:50px;right:80px;overflow:hidden}html.is-spatial .collab-panel{background:#fff3;border:1px solid #ffffff4d}.collab-header{border-bottom:1px solid #0000000f;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.collab-title{color:var(--text-primary);margin:0;font-size:15px;font-weight:600}html.is-spatial .collab-title{color:#ffffffe6}.collab-close{cursor:pointer;color:var(--text-secondary);border-radius:var(--radius-sm);background:0 0;border:none;padding:4px 8px;font-size:16px}.collab-close:hover{background:#0000000f}.collab-body{flex-direction:column;gap:12px;padding:16px;display:flex}.collab-section{flex-direction:column;gap:8px;display:flex}.collab-button{border-radius:var(--radius-lg);color:var(--text-body);cursor:pointer;background:#0000000a;border:1px solid #0000001a;padding:8px 16px;font-size:13px;font-weight:600;transition:all .15s}.collab-button:hover:not(:disabled){background:#00000014}.collab-button:disabled{opacity:.4;cursor:not-allowed}.collab-button-primary{background:rgba(var(--color-primary-rgb), .9);color:#fff;border-color:#0000}.collab-button-primary:hover:not(:disabled){background:rgba(var(--color-primary-rgb), 1)}.collab-button-danger{background:rgba(var(--color-danger-rgb), .1);color:#dc2626;border-color:rgba(var(--color-danger-rgb), .2)}.collab-button-danger:hover:not(:disabled){background:rgba(var(--color-danger-rgb), .2)}.collab-button-reconnect{background:rgba(var(--color-success-rgb), .15);color:var(--color-success);border-color:rgba(var(--color-success-rgb), .3)}.collab-button-reconnect:hover:not(:disabled){background:rgba(var(--color-success-rgb), .25)}.collab-error{background:rgba(var(--color-danger-rgb), .1);border:1px solid rgba(var(--color-danger-rgb), .2);border-radius:var(--radius-sm);color:#fca5a5;margin-bottom:12px;padding:8px 12px;font-size:12px}.collab-hint{color:#9ca3af;text-align:center;margin:0;font-size:12px}.collab-divider{color:#9ca3af;align-items:center;gap:12px;font-size:12px;display:flex}.collab-divider:before,.collab-divider:after{content:"";background:#00000014;flex:1;height:1px}.collab-join-row{gap:8px;display:flex}.collab-input{border-radius:var(--radius-md);font-size:14px;font-weight:600;font-family:var(--font-mono);letter-spacing:1px;text-transform:uppercase;background:#00000005;border:1px solid #0000001a;outline:none;flex:1;padding:8px 12px}.collab-input:focus{border-color:rgba(var(--color-primary-rgb), .5);box-shadow:var(--focus-ring)}.collab-room-code{background:rgba(var(--color-primary-rgb), .06);border-radius:var(--radius-xl);cursor:pointer;flex-direction:column;align-items:center;gap:4px;padding:12px;transition:background .15s;display:flex}.collab-room-code:hover{background:rgba(var(--color-primary-rgb), .12)}.collab-code-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:500}.collab-code-value{font-size:24px;font-weight:700;font-family:var(--font-mono);color:var(--color-primary-dark);letter-spacing:2px}.collab-code-copy{color:var(--text-secondary);font-size:11px}.collab-peers-header{justify-content:space-between;align-items:center;display:flex}.collab-peers-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.collab-status-dot{background:var(--color-success);width:8px;height:8px;box-shadow:0 0 6px rgba(var(--color-success-rgb), .5);border-radius:50%}.collab-peers-list{flex-direction:column;gap:6px;display:flex}.collab-peer{border-radius:var(--radius-md);background:#00000005;align-items:center;gap:8px;padding:6px 8px;display:flex}.collab-peer-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.collab-peer-name{color:var(--text-body);font-size:13px;font-weight:500}.collab-waiting{color:#9ca3af;margin:0;padding:4px 0;font-size:12px;font-style:italic}.collab-indicator{border-radius:var(--radius-md);background:rgba(var(--color-success-rgb), .1);color:#16a34a;cursor:pointer;align-items:center;gap:4px;padding:4px 8px;font-size:11px;font-weight:600;display:flex}.collab-indicator-dot{background:var(--color-success);border-radius:50%;width:6px;height:6px;animation:2s infinite collab-pulse}@keyframes collab-pulse{0%,to{opacity:1}50%{opacity:.4}}.tag-bar{z-index:1100;--xr-background-material:thin;--xr-back:0;position:fixed;top:72px;left:50%;transform:translate(-50%)}.tag-bar-inner{-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:#0f0a2899;border:1px solid #ffffff1a;border-radius:20px;align-items:center;gap:6px;max-width:80vw;padding:6px 12px;display:flex;overflow-x:auto;box-shadow:0 2px 12px #0003,inset 0 1px #ffffff14}html.is-spatial .tag-bar{--xr-back:6;width:fit-content;max-width:500px;margin:0 auto;top:56px;left:0;right:0;transform:none}html.is-spatial .tag-bar-inner{max-width:100%;box-shadow:none;background:#ffffff26;flex-wrap:wrap;overflow-x:hidden}.tag-pill{color:#ffffffbf;cursor:pointer;white-space:nowrap;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:600;transition:all .15s;display:flex}.tag-pill:hover{background:rgba(var(--color-primary-rgb), .2);border-color:rgba(var(--color-primary-rgb), .4);color:#fffffff2}.tag-pill-active{background:rgba(var(--color-primary-rgb), .3);border-color:rgba(var(--color-primary-rgb), .6);color:#c7d2fe}.tag-pill-count{opacity:.6;font-size:10px}.tag-pill-add{color:#fff6;border-style:dashed;border-color:#ffffff26}.tag-pill-clear{color:#fca5a5;border-color:rgba(var(--color-danger-rgb), .25)}.tag-pill-clear:hover{background:rgba(var(--color-danger-rgb), .15);color:#fecaca}.tag-add-inline{display:flex}.tag-add-input{border:1px dashed rgba(var(--color-primary-rgb), .4);background:rgba(var(--color-primary-rgb), .05);border-radius:20px;outline:none;width:100px;padding:3px 8px;font-size:12px}.tag-add-input:focus{border-color:rgba(var(--color-primary-rgb), .6)}.tag-bar-divider{background:#ffffff26;flex-shrink:0;width:1px;height:16px}.tag-bar-count{color:#ffffff80;white-space:nowrap;font-size:11px}.drawing-toolbar{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:10001;background:#0f172aeb;border:1px solid #ffffff26;border-radius:14px;align-items:center;gap:6px;padding:8px 14px;display:flex;position:fixed;bottom:20px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #0000004d}.drawing-tool-btn{border-radius:var(--radius-md);color:#fff;cursor:pointer;background:#ffffff14;border:none;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;transition:background .15s;display:flex}.drawing-tool-btn:hover{background:#ffffff2e}.drawing-tool-btn.active{background:rgba(var(--color-primary-rgb), .7);box-shadow:0 0 0 2px rgba(var(--color-primary-rgb), .4)}.drawing-color-btn{cursor:pointer;border:2px solid #0000;border-radius:50%;width:24px;height:24px;transition:transform .15s,border-color .15s}.drawing-color-btn:hover{transform:scale(1.2)}.drawing-color-btn.active{border-color:#fff;box-shadow:0 0 0 2px #ffffff4d}.drawing-separator{background:#fff3;width:1px;height:24px;margin:0 4px}.board-picker-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10000;background:#0000004d;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.board-picker{-webkit-backdrop-filter:blur(40px);backdrop-filter:blur(40px);--xr-background-material:thick;background:#fffffffa;border:1px solid #fff9;border-radius:20px;flex-direction:column;width:480px;max-height:80vh;display:flex;overflow:hidden;box-shadow:0 16px 64px #0003}html.is-spatial .board-picker{--xr-back:0;--xr-z-index:9999;background:#ffffff26}.board-picker-standalone{width:100%;max-height:100vh;box-shadow:none;border:none;border-radius:0}.board-picker-window-scene{background:linear-gradient(135deg,#18181c 0%,#222227 100%);min-height:100vh}html.is-spatial .board-picker-window-scene{--xr-background-material:translucent;background:0 0}.board-picker-header{border-bottom:1px solid #0000000f;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.board-picker-title{color:var(--text-primary);margin:0;font-size:18px;font-weight:700}html.is-spatial .board-picker-title{color:#ffffffe6}.board-picker-close{cursor:pointer;color:var(--text-secondary);border-radius:var(--radius-sm);background:0 0;border:none;padding:4px 8px;font-size:18px}.board-picker-close:hover{background:#0000000f}.board-picker-list{flex-direction:column;gap:8px;padding:12px;display:flex;overflow-y:auto}.board-picker-card{border-radius:var(--radius-xl);cursor:pointer;background:#00000003;border:1px solid #0000000f;align-items:center;gap:12px;padding:10px 12px;transition:all .15s;display:flex;position:relative}.board-picker-card:hover{background:rgba(var(--color-primary-rgb), .04);border-color:rgba(var(--color-primary-rgb), .15)}.board-picker-card.active{background:rgba(var(--color-primary-rgb), .08);border-color:rgba(var(--color-primary-rgb), .3)}.board-picker-thumb{border-radius:var(--radius-sm);background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);flex-shrink:0;width:56px;height:42px;overflow:hidden}.board-picker-thumb img{object-fit:cover;width:100%;height:100%}.board-picker-thumb-placeholder{color:#fff;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;font-weight:700;display:flex}.board-picker-thumb-placeholder span{font-size:16px}.board-picker-thumb-placeholder small{opacity:.7;font-size:8px}.board-picker-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.board-picker-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;overflow:hidden}.board-picker-edit-input{border:1px solid rgba(var(--color-primary-rgb), .4);border-radius:var(--radius-xs);background:#fff;outline:none;padding:2px 6px;font-size:14px;font-weight:600}.board-picker-meta{color:#9ca3af;font-size:11px}.board-picker-actions{opacity:0;gap:4px;transition:opacity .15s;display:flex}.board-picker-card:hover .board-picker-actions{opacity:1}.board-picker-action{border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);background:#0000000d;border:none;padding:4px 8px;font-size:14px}.board-picker-action:hover{background:#0000001a}.board-picker-action-danger:hover{background:rgba(var(--color-danger-rgb), .15);color:#dc2626}.board-picker-active-badge{text-transform:uppercase;letter-spacing:.5px;color:var(--color-primary-dark);background:rgba(var(--color-primary-rgb), .1);border-radius:var(--radius-xs);padding:2px 6px;font-size:9px;font-weight:700;position:absolute;top:8px;right:8px}.board-picker-new-btn{border-radius:var(--radius-xl);color:var(--text-secondary);cursor:pointer;background:0 0;border:2px dashed #0000001a;padding:12px;font-size:14px;font-weight:600;transition:all .15s}.board-picker-new-btn:hover{border-color:rgba(var(--color-primary-rgb), .3);color:var(--color-primary-dark);background:rgba(var(--color-primary-rgb), .04)}.board-picker-create-card{border-style:dashed;border-color:rgba(var(--color-primary-rgb), .3)}.command-category{text-transform:uppercase;letter-spacing:.5px;color:#9ca3af;padding:4px 12px 2px;font-size:10px;font-weight:700}.export-options-scene{color:#f1f5f9;min-height:100vh;font-family:var(--font-sans);background:linear-gradient(135deg,#1e1b2e 0%,#2d2640 50%,#1a1a2e 100%);padding:24px}.export-options-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.export-options-title{background:linear-gradient(135deg,#818cf8,#a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:0;font-size:22px;font-weight:700}.export-options-close{color:var(--text-muted);cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:24px;transition:all .2s;display:flex}.export-options-close:hover{color:#f1f5f9;background:#fff3}.export-options-stats{border-radius:var(--radius-lg);color:var(--text-muted);background:#ffffff0f;gap:16px;margin-bottom:20px;padding:10px 16px;font-size:13px;display:flex}.export-options-stats span{align-items:center;gap:4px;display:flex}.export-options-grid{flex-direction:column;gap:12px;margin-bottom:20px;display:flex}.export-option-card{cursor:pointer;text-align:left;color:#f1f5f9;background:#ffffff0f;border:1px solid #ffffff14;border-radius:14px;align-items:center;gap:16px;padding:16px 20px;font-family:inherit;transition:all .2s;display:flex}.export-option-card:hover:not(:disabled){background:#ffffff1f;border-color:#818cf84d;transform:translateY(-1px)}.export-option-card:disabled{opacity:.4;cursor:not-allowed}.export-option-card.done{background:#22c55e1a;border-color:#22c55e66}.export-option-icon{text-align:center;flex-shrink:0;width:40px;font-size:28px}.export-option-label{font-size:15px;font-weight:600;display:block}.export-option-desc{color:var(--text-muted);margin-top:2px;font-size:12px;display:block}.export-share-link{gap:8px;margin-bottom:16px;display:flex}.export-share-input{border-radius:var(--radius-lg);color:#e2e8f0;font-size:12px;font-family:var(--font-mono);background:#0000004d;border:1px solid #ffffff1a;flex:1;padding:10px 14px}.export-share-copy{background:linear-gradient(135deg, var(--color-primary), #8b5cf6);border-radius:var(--radius-lg);color:#fff;cursor:pointer;border:none;padding:10px 18px;font-size:13px;font-weight:600;transition:all .2s}.export-share-copy:hover{transform:translateY(-1px);box-shadow:0 4px 16px #6366f166}.export-options-hint{color:#64748b;text-align:center;margin:0;font-size:12px}.template-picker-scene{color:#f1f5f9;min-height:100vh;font-family:var(--font-sans);background:linear-gradient(135deg,#1e1b2e 0%,#2d2640 50%,#1a1a2e 100%);padding:24px}.template-picker-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.template-picker-title{background:linear-gradient(135deg,#818cf8,#a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:0;font-size:22px;font-weight:700}.template-picker-close{color:var(--text-muted);cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:24px;transition:all .2s;display:flex}.template-picker-close:hover{color:#f1f5f9;background:#fff3}.template-picker-categories{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.template-category-btn{color:var(--text-muted);cursor:pointer;background:#ffffff0f;border:1px solid #ffffff14;border-radius:20px;padding:6px 14px;font-size:12px;font-weight:500;transition:all .2s}.template-category-btn:hover{color:#e2e8f0;background:#ffffff1f}.template-category-btn.active{color:#a5b4fc;background:#6366f133;border-color:#6366f166}.template-picker-grid{flex-direction:column;gap:10px;max-height:360px;padding-right:4px;display:flex;overflow-y:auto}.template-picker-grid::-webkit-scrollbar{width:4px}.template-picker-grid::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.template-card{border-radius:var(--radius-xl);background:#ffffff0f;border:1px solid #ffffff14;align-items:center;gap:14px;padding:14px 16px;transition:all .2s;display:flex}.template-card:hover{background:#ffffff1a;border-color:#818cf833}.template-card-icon{text-align:center;flex-shrink:0;width:40px;font-size:28px}.template-card-info{flex:1;min-width:0}.template-card-name{color:#e2e8f0;margin:0 0 2px;font-size:14px;font-weight:600}.template-card-desc{color:var(--text-muted);margin:0;font-size:12px;line-height:1.3}.template-card-btn{background:linear-gradient(135deg, var(--color-primary), #8b5cf6);border-radius:var(--radius-md);color:#fff;cursor:pointer;border:none;flex-shrink:0;padding:8px 16px;font-size:12px;font-weight:600;transition:all .2s}.template-card-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}.template-card-btn.applied{background:linear-gradient(135deg, var(--color-success), #16a34a)}.template-picker-hint{color:#64748b;text-align:center;margin:16px 0 0;font-size:12px}.toast-container{z-index:10000;pointer-events:none;flex-direction:column-reverse;gap:8px;display:flex;position:fixed;bottom:48px;left:50%;transform:translate(-50%)}.toast{border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);pointer-events:auto;white-space:nowrap;align-items:center;gap:8px;padding:10px 18px;font-size:13px;font-weight:500;display:flex;box-shadow:0 4px 20px #0000004d}.toast-enter{animation:.25s ease-out toast-in}.toast-exit{animation:.25s ease-in forwards toast-out}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes toast-out{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-8px)scale(.95)}}.toast-info{color:#e2e8f0;background:#1e1e2ee6;border:1px solid #ffffff1a}.toast-success{color:#bbf7d0;background:#166534e6;border:1px solid #22c55e4d}.toast-warning{color:#fef08a;background:#785000e6;border:1px solid #f59e0b4d}.toast-error{color:#fecaca;background:#7f1d1de6;border:1px solid #ef44444d}.toast-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;font-size:14px;font-weight:700;display:flex}.toast-info .toast-icon{background:#6366f14d}.toast-success .toast-icon{background:#22c55e4d}.toast-warning .toast-icon{background:#f59e0b4d}.toast-error .toast-icon{background:#ef44444d}.toast-message{line-height:1.2}.shortcuts-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9500;background:#0009;justify-content:center;align-items:center;animation:.15s ease-out fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.shortcuts-panel{border-radius:var(--radius-2xl);background:linear-gradient(135deg,#1e1b2e,#2d2640);border:1px solid #ffffff1a;width:90vw;max-width:640px;max-height:80vh;padding:28px 32px;overflow-y:auto;box-shadow:0 16px 64px #00000080}.shortcuts-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.shortcuts-title{color:#e2e8f0;margin:0;font-size:20px;font-weight:700}.shortcuts-close{color:var(--text-muted);cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:22px;display:flex}.shortcuts-close:hover{color:#fff;background:#fff3}.shortcuts-grid{grid-template-columns:1fr 1fr;gap:24px;display:grid}.shortcuts-group{flex-direction:column;gap:8px;display:flex}.shortcuts-group-title{text-transform:uppercase;letter-spacing:.5px;color:#818cf8;margin:0 0 4px;font-size:12px;font-weight:700}.shortcuts-group-note{color:#fff6;margin:0 0 6px;font-size:10px;font-style:italic}.shortcuts-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.shortcuts-keys{flex-shrink:0;align-items:center;gap:2px;display:flex}.shortcuts-kbd{color:#e2e8f0;text-align:center;background:#ffffff1a;border:1px solid #ffffff26;border-radius:5px;justify-content:center;align-items:center;min-width:22px;padding:2px 7px;font-family:inherit;font-size:11px;display:inline-flex}.shortcuts-plus{color:#64748b;margin:0 1px;font-size:10px}.shortcuts-desc{color:var(--text-muted);text-align:right;font-size:12px}.shortcuts-footer{text-align:center;color:#64748b;border-top:1px solid #ffffff0f;margin-top:20px;padding-top:16px;font-size:12px}.status-bar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:2000;height:28px;color:var(--text-muted);font-size:11px;font-family:var(--font-sans);background:#0f0f19f2;border-top:1px solid #ffffff14;justify-content:space-between;align-items:center;padding:0 16px;display:flex;position:fixed;bottom:0;left:0;right:0}html.is-spatial .status-bar{display:none}.status-bar-left,.status-bar-center,.status-bar-right{align-items:center;gap:12px;display:flex}.status-bar-center{gap:8px}.status-item{align-items:center;gap:3px;display:flex}.status-item-dim{color:#64748b}.status-item-highlight{color:#a5b4fc;font-weight:500}.status-badge{border-radius:var(--radius-lg);text-transform:uppercase;letter-spacing:.3px;align-items:center;padding:1px 8px;font-size:10px;font-weight:600;display:inline-flex}.status-badge-present{color:#fca5a5;background:#ef444433;border:1px solid #ef44444d}.status-badge-drawing{color:#fcd34d;background:#f59e0b33;border:1px solid #f59e0b4d}.status-badge-collab{color:#86efac;background:#22c55e33;border:1px solid #22c55e4d}.status-badge-filter{color:#a5b4fc;background:#6366f133;border:1px solid #6366f14d}.status-badge-flat{color:#fde047;background:#eab30833;border:1px solid #eab3084d}.status-shortcut-hint{font-size:10px}.status-shortcut-hint kbd{color:var(--text-muted);background:#ffffff14;border-radius:3px;padding:0 4px;font-family:inherit;font-size:10px;display:inline}.welcome-quick-tips{border-radius:var(--radius-lg);background:#ffffff0a;border:1px solid #ffffff0f;margin:16px 0 20px;padding:12px 16px}.welcome-tip{color:var(--text-muted);margin:4px 0;font-size:12px;line-height:1.5}.welcome-tip:before{content:"•";color:var(--color-primary)}.welcome-tip kbd{border-radius:var(--radius-xs);color:#e2e8f0;background:#ffffff1a;border:1px solid #ffffff26;padding:1px 5px;font-family:inherit;font-size:11px;display:inline}.item-image-error{background:rgba(var(--color-danger-rgb), .1);border:1px dashed rgba(var(--color-danger-rgb), .3);border-radius:var(--radius-md);width:100%;height:100%;min-height:80px;color:rgba(var(--color-danger-rgb), .7);text-align:center;justify-content:center;align-items:center;padding:12px;font-size:12px;display:flex}.empty-board-hint{text-align:center;pointer-events:none;z-index:100;opacity:.6;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.empty-board-icon{color:#ffffff4d;border-radius:var(--radius-2xl);border:2px dashed #fff3;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 12px;font-size:48px;display:flex}.empty-board-text{color:#ffffff80;margin-bottom:8px;font-size:16px}.empty-board-subtext{color:#ffffff4d;font-size:13px}.empty-board-subtext kbd{border-radius:var(--radius-xs);background:#ffffff14;border:1px solid #ffffff1f;padding:1px 5px;font-family:inherit;font-size:12px;display:inline}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10000;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-card{border-radius:var(--radius-2xl);background:#fff;max-width:90vw;max-height:80vh;overflow-y:auto;box-shadow:0 16px 48px #0003}.modal-card .clear-scene,.modal-card .grid-align-scene,.modal-card .export-scene,.modal-card .import-scene,.modal-card .export-options-scene,.modal-card .template-picker-scene{color:#1e293b;background:0 0;min-height:auto}.floating-help-content .help-scene{color:#1e293b;background:0 0;min-height:auto;padding:0}.floating-help-content .help-container{padding:0}.floating-help-content .help-header{display:none}.floating-help-content .help-section-title{color:var(--text-body)}.floating-help-content .help-item{color:#4b5563}.floating-help-content kbd{color:var(--text-body);background:#0000000f;border-color:#0000001f}.modal-backdrop{z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-panel{border-radius:var(--radius-xl);background:#1e1e2e;border:1px solid #ffffff1a;min-width:380px;max-width:90vw;padding:24px;box-shadow:0 20px 60px #00000080}.modal-title{color:#e2e8f0;margin-bottom:16px;font-size:16px;font-weight:600}.modal-input{border-radius:var(--radius-md);color:#e2e8f0;background:#ffffff0f;border:1px solid #ffffff26;outline:none;width:100%;margin-bottom:16px;padding:10px 12px;font-size:14px}.modal-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(var(--color-primary-rgb), .25)}.modal-actions{justify-content:flex-end;gap:8px;display:flex}.modal-btn{border-radius:var(--radius-md);cursor:pointer;border:none;padding:8px 16px;font-size:13px;font-weight:500}.modal-btn-secondary{color:var(--text-muted);background:#ffffff0f}.modal-btn-secondary:hover{background:#ffffff1a}.modal-btn-primary{background:var(--color-primary);color:#fff}.modal-btn-primary:hover{background:#5558e6}.modal-btn-primary:disabled{opacity:.4;cursor:not-allowed}.pan-pad{cursor:grab;touch-action:none;z-index:1000;--xr-background-material:thick;--xr-back:0;--xr-z-index:100;background:#ffffff1a;border:1px solid #ffffff26;border-radius:24px;justify-content:center;align-items:center;width:120px;height:120px;display:flex;position:fixed;bottom:24px;right:24px}.pan-pad:active{cursor:grabbing;background:#ffffff2e}.item-model-error,.item-model-usdz-fallback{border-radius:var(--radius-md);flex-direction:column;justify-content:center;align-items:center;gap:6px;width:200px;height:200px;display:flex}.item-model-error{background:rgba(var(--color-danger-rgb), .08);border:1px solid rgba(var(--color-danger-rgb), .3);color:var(--text-muted)}.item-model-usdz-fallback{background:rgba(var(--color-primary-rgb), .08);color:#64748b}.item-model-error span,.item-model-usdz-fallback span{text-align:center;padding:0 12px;font-size:11px}.zoom-controls{border-radius:var(--radius-lg);box-shadow:var(--shadow-md);z-index:900;background:#f8fafcfa;border:1px solid #0000000f;align-items:center;gap:2px;padding:4px;display:flex;position:fixed;bottom:36px;right:20px}html.is-spatial .zoom-controls{-webkit-backdrop-filter:blur(40px);backdrop-filter:blur(40px);--xr-background-material:thin;background:#ffffff59;border:1px solid #ffffff40;bottom:24px;right:160px}.zoom-controls-btn{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-body);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;display:flex}.zoom-controls-btn:hover{background:rgba(var(--color-primary-rgb), .1);color:var(--color-primary)}.zoom-controls-btn:disabled{opacity:.35;cursor:default}.zoom-controls-btn:disabled:hover{color:var(--text-body);background:0 0}.zoom-controls-value{border-radius:var(--radius-sm);min-width:44px;height:28px;color:var(--text-body);font-variant-numeric:tabular-nums;cursor:pointer;background:0 0;border:none;font-size:11px;font-weight:600}.zoom-controls-value:hover{background:rgba(var(--color-primary-rgb), .1);color:var(--color-primary)}.zoom-controls-sep{background:#0000001a;width:1px;height:16px;margin:0 2px}html.is-spatial .zoom-controls-btn,html.is-spatial .zoom-controls-value{color:#fffffff2}html.is-spatial .zoom-controls-sep{background:#ffffff40}.spatial-btn:focus-visible,.spatial-popover-item:focus-visible,.layer-action-btn:focus-visible,.filter-btn:focus-visible,.tag-pill:focus-visible,.zoom-controls-btn:focus-visible,.zoom-controls-value:focus-visible,.floating-panel-close:focus-visible,.drawing-tool-btn:focus-visible,.present-ctrl-btn:focus-visible,.welcome-step-dot:focus-visible,.board-picker-action:focus-visible,.review-action-btn:focus-visible,.item-delete-button:focus-visible,.item-edit-button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.spatial-btn:disabled{cursor:not-allowed}.account-control{justify-content:center;align-items:center;width:30px;height:30px;display:flex}.account-avatar-signedout{background:rgba(var(--color-primary-rgb), .12);width:30px;height:30px;color:var(--color-primary);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.account-avatar-signedout:hover{background:rgba(var(--color-primary-rgb), .2)}.account-avatar-signedout:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.account-control .cl-userButtonTrigger,.account-control .cl-avatarBox{width:30px;height:30px}.signin-scene{background:#f8fafcfa;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:16px;display:flex}html.is-spatial .signin-scene{--xr-background-material:regular;background:0 0}.signin-scene-done{text-align:center;color:var(--text-body);flex-direction:column;align-items:center;gap:12px;font-size:15px;display:flex}.signin-scene-check{background:rgba(var(--color-success-rgb), .15);width:48px;height:48px;color:var(--color-success);border-radius:50%;justify-content:center;align-items:center;font-size:26px;font-weight:700;display:flex}
