/*! tailwindcss v4.3.0 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-duration:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:var(--font-sans);--font-mono:var(--font-mono);--color-red-500:oklch(63.7% .237 25.331);--color-orange-500:oklch(70.5% .213 47.604);--color-yellow-500:oklch(79.5% .184 86.047);--color-green-500:oklch(72.3% .219 149.579);--color-blue-500:oklch(62.3% .214 259.815);--color-gray-500:oklch(55.1% .027 264.364);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-xs:20rem;--container-md:28rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height: 1.5 ;--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-2xl:1.5rem;--font-weight-normal:var(--font-weight-normal);--font-weight-medium:var(--font-weight-medium);--font-weight-semibold:var(--font-weight-semibold);--font-weight-bold:var(--font-weight-bold);--tracking-tight:var(--tracking-tight);--tracking-normal:var(--tracking-normal);--tracking-wide:var(--tracking-wide);--tracking-wider:var(--tracking-wider);--tracking-widest:var(--tracking-widest);--leading-tight:var(--leading-tight);--leading-snug:1.375;--leading-normal:var(--leading-normal);--leading-relaxed:var(--leading-relaxed);--radius-sm:var(--radius-sm);--radius-md:var(--radius-md);--radius-lg:var(--radius-lg);--radius-xl:var(--radius-xl);--radius-2xl:1rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000001a;--ease-out:cubic-bezier(0, 0, .2, 1);--animate-spin:spin 1s linear infinite;--animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--leading-none:var(--leading-none)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}:root{--surface-app:#121416;--surface-stage:#171b1f;--surface-panel:#1d2227;--surface-panel-active:#232a31;--surface-floating:#191f25eb;--surface-hover:#ffffff0e;--surface-active:#ffffff18;--bg-primary:var(--surface-app);--bg-secondary:var(--surface-stage);--bg-tertiary:#242a31;--bg-hover:var(--surface-hover);--bg-active:var(--surface-active);--border-subtle:#ffffff0d;--border-strong:#313941;--border-light:#434d57;--border:var(--border-strong);--text-primary:#fff;--text-secondary:#a1acb7;--text-tertiary:#b7c0c9;--text-muted:#7e8894;--text-disabled:#535e69;--text-inverse:#101315;--accent-50:#ecfffb;--accent-100:#c8fff6;--accent-200:#95f5ea;--accent-300:#5fe6db;--accent-400:#2fd4c8;--accent-500:#1bb7ab;--accent-600:#11998e;--accent-700:#0e7a72;--accent-800:#0f625d;--accent-900:#0f4f4c;--accent:#2fd4c8;--accent-hover:#51e4d9;--accent-soft:#2fd4c829;--accent-text:#081111;--selection:#2fd4c8;--selection-subtle:#2fd4c833;--selection-outline:#8cefe6;--danger-50:#fef2f2;--danger-100:#fee2e2;--danger-200:#fecaca;--danger-300:#fca5a5;--danger-400:#f87171;--danger-500:#ef4444;--danger-600:#dc2626;--danger-700:#b91c1c;--danger-800:#991b1b;--danger-900:#7f1d1d;--success-50:#ecfdf5;--success-100:#d1fae5;--success-200:#a7f3d0;--success-300:#6ee7b7;--success-400:#34d399;--success-500:#10b981;--success-600:#059669;--success-700:#047857;--success-800:#065f46;--success-900:#064e3b;--warning-50:#fffbeb;--warning-100:#fef3c7;--warning-200:#fde68a;--warning-300:#fcd34d;--warning-400:#fbbf24;--warning-500:#f59e0b;--warning-600:#d97706;--warning-700:#b45309;--warning-800:#92400e;--warning-900:#78350f;--info-50:#eff6ff;--info-100:#dbeafe;--info-200:#bfdbfe;--info-300:#93c5fd;--info-400:#60a5fa;--info-500:#3b82f6;--info-600:#2563eb;--info-700:#1d4ed8;--info-800:#1e40af;--info-900:#1e3a8a;--danger:#ef4444;--danger-soft:#ef444426;--success:#10b981;--success-soft:#10b98126;--warning:#f59e0b;--info:#3b82f6;--overlay:#0009;--red:var(--danger);--blue:var(--info);--green:var(--success);--amber:var(--warning);--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-12:48px;--space-16:64px;--ms--2:5px;--ms--1:6px;--ms-0:8px;--ms-1:10px;--ms-2:13px;--ms-3:16px;--ms-4:20px;--ms-5:24px;--ms-6:31px;--ms-7:38px;--ms-8:48px;--ms-9:60px;--ms-10:74px;--radius-sm:4px;--radius-md:6px;--radius:8px;--radius-lg:10px;--radius-xl:12px;--radius-full:9999px;--shadow-sm:0 1px 3px #00000042;--shadow-md:0 10px 24px #00000047;--shadow-lg:0 20px 40px #00000057;--shadow-xl:0 28px 68px #0000006b;--transition-hover:80ms ease;--transition-overlay:.12s ease;--transition-snap:60ms ease;--transition-toast:.18s ease;--transition-panel:.16s ease;--font-sans:"Raleway", "Raleway-fallback", system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono:"SF Mono", "Fira Code", "Cascadia Code", monospace;--text-xs:11px;--text-sm:12px;--text-base:13px;--text-md:14px;--text-lg:18px;--text-xl:20px;--text-2xl:24px;--text-tool-label:11px;--text-section-label:11px;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--leading-none:1;--leading-tight:1.25;--leading-normal:1.5;--leading-relaxed:1.625;--tracking-tight:-.01em;--tracking-normal:0;--tracking-wide:.02em;--tracking-wider:.05em;--tracking-widest:.1em;--sidebar-width:240px;--components-library-width:280px;--header-height:40px;--toolrail-width:56px;--panel-width:280px}[data-theme=light]{--surface-app:#eef1f3;--surface-stage:#f7f9fa;--surface-panel:#ffffffe0;--surface-panel-active:#fff;--surface-floating:#ffffffe6;--surface-hover:#08141a0d;--surface-active:#08141a14;--bg-primary:var(--surface-app);--bg-secondary:var(--surface-stage);--bg-tertiary:#e5eaee;--border-subtle:#0b161d14;--border-strong:#cfd8de;--border-light:#dbe3e8;--border:var(--border-strong);--text-primary:#182027;--text-secondary:#54606c;--text-tertiary:#6b7781;--text-muted:#74808a;--text-disabled:#a0a9b0;--text-inverse:#fff;--accent:#13877f;--accent-hover:#0f746d;--accent-soft:#13877f1f;--accent-text:#fff;--selection:#13877f;--selection-subtle:#13877f29;--selection-outline:#0f746d;--danger-soft:#ef444414;--success-soft:#10b98114;--overlay:#0000004d;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 12px #0000001a;--shadow-lg:0 8px 32px #00000026;--shadow-xl:0 12px 48px #0003}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--surface-app);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-md);-webkit-font-smoothing:antialiased;line-height:1.5}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}::selection{background:var(--accent);color:var(--accent-text)}input,textarea,select,button{font-family:var(--font-sans);font-size:var(--text-md)}button,.btn,.btn-icon,[role=button]{outline:none;transition:background .1s,color .1s,border-color .1s,opacity .1s}button:focus-visible,.btn:focus-visible,.btn-icon:focus-visible,[tabindex]:focus-visible{box-shadow:0 0 0 2px var(--accent)}button:active,.btn:active,.btn-icon:active{transform:scale(.97)}*{scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@font-face{font-family:Raleway-fallback;size-adjust:96%;ascent-override:90%;descent-override:22%;src:local("system-ui"),local("sans-serif")}}@layer components{.btn{border-radius:var(--radius-md);font-size:var(--text-sm);cursor:pointer;white-space:nowrap;border:none;justify-content:center;align-items:center;gap:6px;padding:6px 14px;font-weight:500;line-height:1.4;transition:background .15s,opacity .15s;display:inline-flex}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);color:var(--accent-text)}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{border:1px solid var(--border);color:var(--text-primary);background:0 0}.btn-secondary:hover:not(:disabled){background:var(--bg-hover)}.btn-ghost{color:var(--text-secondary);background:0 0;padding:4px 8px}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-icon{border-radius:var(--radius-md);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;transition:background .15s,color .15s;display:inline-flex}.btn-icon:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-icon.active{color:var(--accent);background:#a855f71a}.btn-graph{cursor:pointer;white-space:nowrap;border:1px solid var(--border);background:var(--bg-secondary);height:32px;color:var(--text-primary);border-radius:6px;align-items:center;gap:4px;padding:0 12px;font-size:11px;display:inline-flex}.btn-graph:hover{background:var(--bg-hover)}.input{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);font-size:var(--text-sm);outline:none;padding:6px 10px;transition:border-color .15s}.input::placeholder{color:var(--text-muted)}.input:focus{border-color:var(--accent)}.input-sm{font-size:var(--text-xs);padding:4px 8px}.card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4)}.panel{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);pointer-events:auto;-webkit-user-select:none;user-select:none}.panel-header{padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border);font-weight:600;font-size:var(--text-sm)}.panel-content{padding:var(--space-3)}.draggable-panel{transition:left .2s cubic-bezier(.2,.9,.4,1.1),top .2s cubic-bezier(.2,.9,.4,1.1)}.draggable-panel:active{transition:none}.draggable-panel.sticking{border-left:2px solid var(--accent)}.stick-indicator{background:var(--accent);opacity:.6;pointer-events:none;border-radius:2px;width:4px;height:16px;position:absolute;top:50%;left:-6px;transform:translateY(-50%)}.draggable-panel:active .stick-indicator{opacity:0}.components-library{width:var(--components-library-width);background:var(--bg-secondary);border-right:1px solid var(--border);flex-direction:column;display:flex;overflow:hidden}.library-header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border)}.library-tabs{border-bottom:1px solid var(--border);display:flex}.library-tabs button{padding:var(--space-2);color:var(--text-secondary);font-size:var(--text-xs);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1}.library-tabs button:hover{color:var(--text-primary)}.library-tabs button.active{color:var(--accent);border-bottom-color:var(--accent)}.library-items{gap:var(--space-2);padding:var(--space-3) var(--space-4);flex:1;grid-template-columns:repeat(2,1fr);align-content:start;display:grid;overflow-y:auto}.library-item{padding:var(--space-3);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:grab;flex-direction:column;align-items:center;gap:4px;transition:all .15s;display:flex;position:relative}.library-item:hover{border-color:var(--accent);background:var(--bg-tertiary)}.library-item:active{cursor:grabbing}.item-icon{font-size:28px;line-height:1}.item-name{font-size:var(--text-xs);color:var(--text-secondary);text-align:center;text-overflow:ellipsis;white-space:nowrap;max-width:100%;line-height:1.3;overflow:hidden}.editor-layout{background:var(--surface-app);height:100vh;display:flex;overflow:hidden}.editor-header{padding:0 var(--space-4);height:var(--header-height);border-bottom:1px solid var(--border);background:var(--bg-primary);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.editor-title{font-size:var(--text-lg);color:var(--text-primary);font-weight:600}.canvas-container{flex:1;position:relative}.modal-overlay{z-index:1000;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}.modal-content{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-5);min-width:380px;max-width:90vw;box-shadow:var(--shadow-xl)}.modal-title{font-size:var(--text-lg);margin-bottom:var(--space-4);color:var(--text-primary);font-weight:600}.modal-actions{justify-content:flex-end;gap:var(--space-2);margin-top:var(--space-3);display:flex}.auth-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex}.auth-card{width:100%;max-width:380px;padding:var(--space-8)}.auth-card h1{font-size:var(--text-2xl);margin-bottom:var(--space-6);color:var(--text-primary);font-weight:700}.auth-form{gap:var(--space-4);flex-direction:column;display:flex}.auth-error{color:var(--red);font-size:var(--text-sm)}.auth-footer{margin-top:var(--space-6);text-align:center;font-size:var(--text-sm);color:var(--text-secondary)}.auth-link{color:var(--accent);text-decoration:none}.auth-link:hover{text-decoration:underline}.user-avatar-dot{border-radius:var(--radius-full);color:#fff;width:28px;height:28px;font-size:var(--text-xs);border:2px solid #111519e0;justify-content:center;align-items:center;font-weight:600;display:flex;box-shadow:0 6px 14px #00000038}.remote-cursor{pointer-events:none;z-index:999;transition:left .1s linear,top .1s linear;position:absolute}.version-history-modal{z-index:1000;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}.version-history-content{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-6);min-width:420px;max-width:90vw;max-height:70vh;overflow-y:auto}.version-item{padding:var(--space-3);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.version-restore-btn{border-radius:var(--radius-sm);border:1px solid var(--border);cursor:pointer;font-size:var(--text-xs);background:0 0;padding:4px 10px}.version-restore-btn:hover{background:var(--bg-hover)}.settings-section{margin-bottom:var(--space-4)}.settings-section-title{font-weight:600;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:var(--space-3)}.settings-row{align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);display:flex}.settings-row label{min-width:100px;color:var(--text-secondary);font-size:var(--text-sm)}.dialog-overlay{z-index:999;position:fixed;top:0;right:0;bottom:0;left:0}.dialog{z-index:1000;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-xl);max-height:80vh;box-shadow:var(--shadow-xl);flex-direction:column;display:flex;position:fixed;overflow:hidden}.dialog-header{padding:var(--space-2) var(--space-3);cursor:move;-webkit-user-select:none;user-select:none;border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.dialog-header-title{font-weight:600;font-size:var(--text-sm);color:var(--text-primary)}.dialog-close-btn{cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm);background:0 0;border:none;padding:2px 6px;font-size:16px;transition:color .15s,background .15s}.dialog-close-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.dialog-content{padding:var(--space-3) var(--space-4);flex:1;overflow-y:auto}.frame-element{cursor:pointer;-webkit-user-select:none;user-select:none;position:relative}.frame-element.selected{outline:none}.frame-element .frame-name-input{background:var(--bg-secondary);border:1px solid var(--accent);border-radius:var(--radius-sm);color:var(--text-primary);z-index:10;padding:2px 6px;font-size:11px;position:absolute;top:4px;left:4px}.mini-map{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:150;position:fixed;bottom:16px;right:16px;overflow:hidden}.mini-map-header{border-bottom:1px solid var(--border);color:var(--text-secondary);justify-content:space-between;align-items:center;padding:6px 10px;font-size:11px;font-weight:600;display:flex}.mini-map-header button{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:0 4px;font-size:12px}.mini-map-header button:hover{color:var(--text-primary)}.mini-map canvas{cursor:pointer;display:block}.recent-files-panel{background:var(--surface-panel);border:1px solid var(--border);width:480px;max-height:80vh;box-shadow:0 8px 32px var(--shadow);z-index:1001;border-radius:12px;flex-direction:column;display:flex;position:fixed;top:50%;left:50%;overflow:hidden;transform:translate(-50%,-50%)}.recent-files-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px 12px;display:flex}.recent-files-header h2{color:var(--text-primary);margin:0;font-size:15px;font-weight:600}.recent-files-empty{color:var(--text-tertiary);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:48px 20px;display:flex}.recent-files-empty p{margin:0;font-size:13px}.recent-files-list{flex-direction:column;flex:1;gap:4px;padding:8px;display:flex;overflow-y:auto}.recent-file-card{cursor:pointer;text-align:left;width:100%;color:var(--text-primary);background:0 0;border:none;border-radius:8px;align-items:center;gap:12px;padding:10px;transition:background .15s;display:flex}.recent-file-card:hover{background:var(--surface-hover)}.recent-file-thumb{background:var(--surface-alt);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:36px;display:flex;overflow:hidden}.recent-file-thumb img{object-fit:cover;width:100%;height:100%}.recent-file-thumb-placeholder{width:48px;height:36px;color:var(--text-tertiary);background:var(--surface-alt);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.recent-file-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.recent-file-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.recent-file-meta{color:var(--text-tertiary);gap:8px;font-size:11px;display:flex}.recent-file-path{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.recent-file-remove{color:var(--text-tertiary);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:4px;padding:4px;transition:opacity .15s,background .15s}.recent-file-card:hover .recent-file-remove{opacity:1}.recent-file-remove:hover{background:var(--surface-hover);color:var(--text-danger,#e53935)}.recent-files-footer{border-top:1px solid var(--border);justify-content:flex-end;align-items:center;gap:8px;padding:8px 20px 12px;display:flex}.recent-files-footer>.text-btn{align-items:center;gap:4px;display:inline-flex}.icon-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;display:flex}.icon-btn:hover{background:var(--surface-hover);color:var(--text-primary)}.text-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:12px}.text-btn:hover{background:var(--surface-hover)}.drawer-overlay{z-index:1100;background:#0006;animation:.15s fadeIn;position:fixed;top:0;right:0;bottom:0;left:0}.drawer-panel{background:var(--surface-panel);border-right:1px solid var(--border);z-index:1101;width:320px;box-shadow:4px 0 24px var(--shadow-lg);flex-direction:column;animation:.2s slideInLeft;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.drawer-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 16px 12px;display:flex}.drawer-logo{color:var(--text-primary);align-items:center;gap:8px;font-size:15px;font-weight:600;display:flex}.drawer-logo-mark{background:linear-gradient(135deg,var(--accent),var(--accent));border-radius:6px;width:20px;height:20px}@supports (color:color-mix(in lab,red,red)){.drawer-logo-mark{background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 60%,white))}}.drawer-actions{border-bottom:1px solid var(--border);flex-direction:column;gap:2px;padding:12px 12px 8px;display:flex}.drawer-action-btn{color:var(--text-primary);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;font-size:13px;transition:background .15s;display:flex}.drawer-action-btn:hover{background:var(--surface-hover)}.drawer-shortcut{color:var(--text-tertiary);margin-left:auto;font-size:11px}.drawer-section-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);padding:12px 16px 8px;font-size:11px;font-weight:600}.drawer-empty{text-align:center;color:var(--text-tertiary);padding:24px 16px;font-size:13px}.drawer-list{flex:1;padding:4px 8px;overflow-y:auto}.drawer-item{color:var(--text-primary);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;width:100%;padding:8px 10px;transition:background .15s;display:flex}.drawer-item:hover{background:var(--surface-hover)}.drawer-item-icon{color:var(--text-tertiary);flex-shrink:0}.drawer-item-info{flex:1;min-width:0}.drawer-item-name{white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:6px;font-size:13px;font-weight:500;display:flex;overflow:hidden}.drawer-item-current{color:var(--accent);font-size:10px;font-weight:400}.drawer-item-badge{color:var(--text-tertiary);background:var(--surface-hover);border-radius:4px;padding:1px 6px;font-size:10px;font-weight:400}.drawer-item-meta{color:var(--text-tertiary);margin-top:1px;font-size:11px}.drawer-item-delete{color:var(--text-tertiary);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:4px;padding:4px;transition:opacity .15s,color .15s,background .15s}.drawer-item:hover .drawer-item-delete{opacity:1}.drawer-item-delete:hover{color:var(--text-danger,#e53935);background:var(--surface-hover)}.drawer-footer{border-top:1px solid var(--border);padding:8px 12px}.drawer-footer-btn{color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:8px;width:100%;padding:8px 10px;font-size:12px;transition:background .15s,color .15s;display:flex}.drawer-footer-btn:hover{background:var(--surface-hover);color:var(--text-primary)}.settings-modal{-webkit-user-select:text;user-select:text;overscroll-behavior:contain;overflow-y:auto}.settings-modal *{-webkit-user-select:text;user-select:text}.drawer-share-link{align-items:center;gap:4px;padding:4px 12px 8px;display:flex}.drawer-share-link input{font-family:monospace}.drawer-share-link .icon-btn{width:24px;height:24px;color:var(--text-secondary)}.drawer-share-link .icon-btn:hover{color:var(--accent)}.drawer-confirm-overlay{z-index:10;background:#00000059;justify-content:center;align-items:center;display:flex;position:absolute;top:0;right:0;bottom:0;left:0}.drawer-confirm{background:var(--surface-floating);border:1px solid var(--border);width:280px;box-shadow:0 8px 32px var(--shadow-lg);border-radius:12px;padding:20px}.drawer-confirm-title{color:var(--text-primary);margin-bottom:8px;font-size:14px;font-weight:600}.drawer-confirm-msg{color:var(--text-secondary);margin-bottom:16px;font-size:12px;line-height:1.4}.drawer-confirm-actions{justify-content:flex-end;gap:8px;display:flex}.main-menu-trigger{border:1px solid var(--border-subtle);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;background:linear-gradient(#ffffff0a,#ffffff04);border-radius:999px;justify-content:center;align-items:center;transition:all .15s;display:flex}.main-menu-trigger:hover{background:var(--bg-hover);color:var(--text-primary)}.main-menu-dropdown{top:var(--header-height);background:linear-gradient(180deg,#ffffff09,#ffffff03),var(--surface-floating);border:1px solid var(--border-subtle);min-width:240px;box-shadow:var(--shadow-lg);z-index:1000;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:16px;margin-top:10px;padding:6px 0;position:fixed;left:0;overflow:hidden}.main-menu-section{padding:4px 0}.main-menu-section:not(:last-child){border-bottom:1px solid var(--border);margin-bottom:4px;padding-bottom:4px}.main-menu-section-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:4px 14px;font-size:10px;font-weight:600}.main-menu-item{cursor:pointer;text-align:left;width:100%;color:var(--text-primary);background:0 0;border:none;align-items:center;gap:10px;padding:7px 14px;font-size:13px;transition:background .1s;display:flex}.main-menu-item:hover{background:var(--bg-hover)}.main-menu-item .menu-item-label{flex:1}.main-menu-item .menu-item-shortcut{color:var(--text-muted);font-family:monospace;font-size:11px}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.w-full{width:100%}.h-full{height:100%}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.inset-0{top:0;right:0;bottom:0;left:0}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-100{z-index:100}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-y-auto{overflow-y:auto}.cursor-pointer{cursor:pointer}.cursor-grab{cursor:grab}.cursor-grabbing{cursor:grabbing}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.select-none{-webkit-user-select:none;user-select:none}.fade-in{animation:.2s fadeIn}.snapping-guides{pointer-events:none;z-index:20;transition:opacity 80ms;position:absolute;top:0;right:0;bottom:0;left:0}.snapping-guides.stale{opacity:.2}.snap-guide-vertical{opacity:.4;background:#6965db;width:1px;transition:left 60ms;position:absolute;top:0;bottom:0}.snap-guide-horizontal{opacity:.4;background:#6965db;height:1px;transition:top 60ms;position:absolute;left:0;right:0}.snap-guide-pulse{animation:.12s ease-out snap-pulse}@keyframes snap-pulse{0%{opacity:1;transform:scaleX(1.02)}50%{opacity:.8}to{opacity:.4;transform:scaleX(1)}}.grid-line-vertical{background:var(--text-secondary);opacity:.07;width:1px;position:absolute;top:0;bottom:0}.grid-line-horizontal{background:var(--text-secondary);opacity:.07;height:1px;position:absolute;left:0;right:0}.guide-spacing{pointer-events:none;z-index:21;position:absolute}.guide-centerline{pointer-events:none;z-index:21;width:1px;height:1px;position:absolute}.distance-hud{color:#fff;pointer-events:none;z-index:30;white-space:nowrap;opacity:.85;background:#6965db;border-radius:6px;padding:1px 5px;font-size:10px;font-weight:600;line-height:16px;position:absolute}.resize-indicator{color:#fff;pointer-events:none;z-index:300;white-space:nowrap;background:#000000bf;border-radius:4px;padding:2px 8px;font-family:monospace;font-size:11px;position:fixed}.element-locked{filter:drop-shadow(0 0 2px #0000004d);cursor:not-allowed}.group-highlight{outline-offset:2px;outline:2px dashed #6965db80}.loading-screen{background:var(--bg,#f5f5f5);z-index:9999;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}.spinner{border:3px solid var(--border,#d0d0d0);border-top-color:var(--accent,#6965db);border-radius:50%;width:32px;height:32px;margin:0 auto;animation:.7s linear infinite spin}.loading-content{flex-direction:column;align-items:center;gap:12px;display:flex}.loading-label{color:#888;font-size:13px}@keyframes spin{to{transform:rotate(360deg)}}}@layer utilities{.pointer-events-auto{pointer-events:auto}.pointer-events-none{pointer-events:none}.collapse{visibility:collapse}.invisible{visibility:hidden}.visible{visibility:visible}.visible\!{visibility:visible!important}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.inset-0{inset:calc(var(--spacing) * 0)}.inset-x-2{inset-inline:calc(var(--spacing) * 2)}.top-0{top:calc(var(--spacing) * 0)}.top-0\.5{top:calc(var(--spacing) * .5)}.top-1\/2{top:50%}.top-2{top:calc(var(--spacing) * 2)}.top-4{top:calc(var(--spacing) * 4)}.top-full{top:100%}.-right-0\.5{right:calc(var(--spacing) * -.5)}.right-0{right:calc(var(--spacing) * 0)}.right-1{right:calc(var(--spacing) * 1)}.right-2{right:calc(var(--spacing) * 2)}.right-3{right:calc(var(--spacing) * 3)}.right-4{right:calc(var(--spacing) * 4)}.-bottom-0\.5{bottom:calc(var(--spacing) * -.5)}.bottom-0{bottom:calc(var(--spacing) * 0)}.bottom-1{bottom:calc(var(--spacing) * 1)}.bottom-3{bottom:calc(var(--spacing) * 3)}.bottom-4{bottom:calc(var(--spacing) * 4)}.left-0{left:calc(var(--spacing) * 0)}.left-2{left:calc(var(--spacing) * 2)}.left-full{left:100%}.z-0{z-index:0}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-50{z-index:50}.z-\[5\]{z-index:5}.z-\[15\]{z-index:15}.z-\[100\]{z-index:100}.z-\[200\]{z-index:200}.z-\[300\]{z-index:300}.z-\[400\]{z-index:400}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.m-0{margin:calc(var(--spacing) * 0)}.m-1{margin:calc(var(--spacing) * 1)}.mx-0\.5{margin-inline:calc(var(--spacing) * .5)}.mx-2{margin-inline:calc(var(--spacing) * 2)}.mx-4{margin-inline:calc(var(--spacing) * 4)}.mx-auto{margin-inline:auto}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-1\.5{margin-top:calc(var(--spacing) * 1.5)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-auto{margin-top:auto}.mb-0\.5{margin-bottom:calc(var(--spacing) * .5)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-1\.5{margin-bottom:calc(var(--spacing) * 1.5)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.ml-1{margin-left:calc(var(--spacing) * 1)}.ml-2{margin-left:calc(var(--spacing) * 2)}.ml-auto{margin-left:auto}.box-border{box-sizing:border-box}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-flex{display:inline-flex}.table{display:table}.aspect-square{aspect-ratio:1}.h-1{height:calc(var(--spacing) * 1)}.h-2{height:calc(var(--spacing) * 2)}.h-3{height:calc(var(--spacing) * 3)}.h-3\.5{height:calc(var(--spacing) * 3.5)}.h-4{height:calc(var(--spacing) * 4)}.h-5{height:calc(var(--spacing) * 5)}.h-6{height:calc(var(--spacing) * 6)}.h-7{height:calc(var(--spacing) * 7)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-10{height:calc(var(--spacing) * 10)}.h-11{height:calc(var(--spacing) * 11)}.h-12{height:calc(var(--spacing) * 12)}.h-\[2px\]{height:2px}.h-\[26px\]{height:26px}.h-\[32px\]{height:32px}.h-\[34px\]{height:34px}.h-\[50px\]{height:50px}.h-\[104px\]{height:104px}.h-full{height:100%}.h-px{height:1px}.h-screen{height:100vh}.max-h-\[80vh\]{max-height:80vh}.min-h-0{min-height:calc(var(--spacing) * 0)}.w-0\.5{width:calc(var(--spacing) * .5)}.w-2{width:calc(var(--spacing) * 2)}.w-3{width:calc(var(--spacing) * 3)}.w-3\.5{width:calc(var(--spacing) * 3.5)}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.w-6{width:calc(var(--spacing) * 6)}.w-7{width:calc(var(--spacing) * 7)}.w-8{width:calc(var(--spacing) * 8)}.w-9{width:calc(var(--spacing) * 9)}.w-10{width:calc(var(--spacing) * 10)}.w-11{width:calc(var(--spacing) * 11)}.w-12{width:calc(var(--spacing) * 12)}.w-\[32px\]{width:32px}.w-\[72px\]{width:72px}.w-\[108px\]{width:108px}.w-\[140px\]{width:140px}.w-\[144px\]{width:144px}.w-\[200px\]{width:200px}.w-full{width:100%}.w-px{width:1px}.w-screen{width:100vw}.max-w-\[400px\]{max-width:400px}.max-w-\[420px\]{max-width:420px}.max-w-md{max-width:var(--container-md)}.max-w-xs{max-width:var(--container-xs)}.min-w-0{min-width:calc(var(--spacing) * 0)}.min-w-12{min-width:calc(var(--spacing) * 12)}.min-w-\[44px\]{min-width:44px}.min-w-\[72px\]{min-width:72px}.min-w-\[140px\]{min-width:140px}.min-w-\[220px\]{min-width:220px}.min-w-\[300px\]{min-width:300px}.min-w-\[340px\]{min-width:340px}.flex-1{flex:1}.flex-none{flex:none}.shrink-0{flex-shrink:0}.grow{flex-grow:1}.-translate-y-1\/2{--tw-translate-y: -50% ;translate:var(--tw-translate-x) var(--tw-translate-y)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.cursor-crosshair{cursor:crosshair}.cursor-default{cursor:default}.cursor-grab{cursor:grab}.cursor-grabbing{cursor:grabbing}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.touch-none{touch-action:none}.resize{resize:both}.resize-none{resize:none}.appearance-none{-webkit-appearance:none;-moz-appearance:none;appearance:none}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.grid-cols-8{grid-template-columns:repeat(8,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.items-stretch{align-items:stretch}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-0\.5{gap:calc(var(--spacing) * .5)}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-2\.5{gap:calc(var(--spacing) * 2.5)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-3\.5{gap:calc(var(--spacing) * 3.5)}.gap-px{gap:1px}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)))}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-\[2px\]{border-radius:2px}.rounded-\[3px\]{border-radius:3px}.rounded-\[4px\]{border-radius:4px}.rounded-\[6px\]{border-radius:6px}.rounded-\[8px\]{border-radius:8px}.rounded-\[10px\]{border-radius:10px}.rounded-\[12px\]{border-radius:12px}.rounded-\[14px\]{border-radius:14px}.rounded-\[18px\]{border-radius:18px}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-t-\[8px\]{border-top-left-radius:8px;border-top-right-radius:8px}.rounded-t-\[10px\]{border-top-left-radius:10px;border-top-right-radius:10px}.rounded-b-\[8px\]{border-bottom-right-radius:8px;border-bottom-left-radius:8px}.border{border-style:var(--tw-border-style);border-width:1px}.border-0{border-style:var(--tw-border-style);border-width:0}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-none{--tw-border-style:none;border-style:none}.border-solid{--tw-border-style:solid;border-style:solid}.border-\[\#6965db\]{border-color:#6965db}.border-\[var\(--accent\)\]{border-color:var(--accent)}.border-\[var\(--border-strong\)\]{border-color:var(--border-strong)}.border-\[var\(--border-subtle\)\]{border-color:var(--border-subtle)}.border-transparent{border-color:#0000}.bg-\[color\:var\(--surface-floating\)\]{background-color:var(--surface-floating)}.bg-\[var\(--accent\)\]{background-color:var(--accent)}.bg-\[var\(--accent-soft\)\]{background-color:var(--accent-soft)}.bg-\[var\(--bg-primary\)\]{background-color:var(--bg-primary)}.bg-\[var\(--border-subtle\)\]{background-color:var(--border-subtle)}.bg-\[var\(--danger-500\)\]{background-color:var(--danger-500)}.bg-\[var\(--info-500\)\]{background-color:var(--info-500)}.bg-\[var\(--success-500\)\]{background-color:var(--success-500)}.bg-\[var\(--surface-hover\)\]{background-color:var(--surface-hover)}.bg-black\/40{background-color:#0006}@supports (color:color-mix(in lab,red,red)){.bg-black\/40{background-color:color-mix(in oklab,var(--color-black) 40%,transparent)}}.bg-blue-500{background-color:var(--color-blue-500)}.bg-gray-500{background-color:var(--color-gray-500)}.bg-green-500{background-color:var(--color-green-500)}.bg-orange-500{background-color:var(--color-orange-500)}.bg-orange-500\/90{background-color:#fe6e00e6}@supports (color:color-mix(in lab,red,red)){.bg-orange-500\/90{background-color:color-mix(in oklab,var(--color-orange-500) 90%,transparent)}}.bg-red-500{background-color:var(--color-red-500)}.bg-transparent{background-color:#0000}.bg-white{background-color:var(--color-white)}.bg-white\/70{background-color:#ffffffb3}@supports (color:color-mix(in lab,red,red)){.bg-white\/70{background-color:color-mix(in oklab,var(--color-white) 70%,transparent)}}.bg-yellow-500{background-color:var(--color-yellow-500)}.p-0{padding:calc(var(--spacing) * 0)}.p-1{padding:calc(var(--spacing) * 1)}.p-1\.5{padding:calc(var(--spacing) * 1.5)}.p-2{padding:calc(var(--spacing) * 2)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-5{padding:calc(var(--spacing) * 5)}.p-6{padding:calc(var(--spacing) * 6)}.p-\[4px_10px\]{padding:4px 10px}.p-\[8px_12px\]{padding:8px 12px}.px-0{padding-inline:calc(var(--spacing) * 0)}.px-1{padding-inline:calc(var(--spacing) * 1)}.px-1\.5{padding-inline:calc(var(--spacing) * 1.5)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.px-\[16px\]{padding-inline:16px}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-2\.5{padding-block:calc(var(--spacing) * 2.5)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-3\.5{padding-block:calc(var(--spacing) * 3.5)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-8{padding-block:calc(var(--spacing) * 8)}.py-\[1px\]{padding-block:1px}.pt-2{padding-top:calc(var(--spacing) * 2)}.pt-4{padding-top:calc(var(--spacing) * 4)}.pt-5{padding-top:calc(var(--spacing) * 5)}.pr-9{padding-right:calc(var(--spacing) * 9)}.pb-1{padding-bottom:calc(var(--spacing) * 1)}.pb-2{padding-bottom:calc(var(--spacing) * 2)}.pb-3{padding-bottom:calc(var(--spacing) * 3)}.pb-4{padding-bottom:calc(var(--spacing) * 4)}.pl-2{padding-left:calc(var(--spacing) * 2)}.text-center{text-align:center}.text-left{text-align:left}.font-mono{font-family:var(--font-mono)}.font-sans{font-family:var(--font-sans)}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[9px\]{font-size:9px}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[12px\]{font-size:12px}.text-\[13px\]{font-size:13px}.text-\[14px\]{font-size:14px}.text-\[15px\]{font-size:15px}.text-\[16px\]{font-size:16px}.text-\[18px\]{font-size:18px}.text-\[20px\]{font-size:20px}.text-\[32px\]{font-size:32px}.leading-4{--tw-leading:calc(var(--spacing) * 4);line-height:calc(var(--spacing) * 4)}.leading-5{--tw-leading:calc(var(--spacing) * 5);line-height:calc(var(--spacing) * 5)}.leading-none{--tw-leading:var(--leading-none);line-height:var(--leading-none)}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.leading-snug{--tw-leading:var(--leading-snug);line-height:var(--leading-snug)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-line{white-space:pre-line}.text-\[var\(--accent\)\]{color:var(--accent)}.text-\[var\(--text-disabled\)\]{color:var(--text-disabled)}.text-\[var\(--text-lg\)\]{color:var(--text-lg)}.text-\[var\(--text-muted\)\]{color:var(--text-muted)}.text-\[var\(--text-primary\)\]{color:var(--text-primary)}.text-\[var\(--text-secondary\)\]{color:var(--text-secondary)}.text-\[var\(--text-sm\)\]{color:var(--text-sm)}.text-\[var\(--text-xs\)\]{color:var(--text-xs)}.text-inherit{color:inherit}.text-white{color:var(--color-white)}.text-white\/80{color:#fffc}@supports (color:color-mix(in lab,red,red)){.text-white\/80{color:color-mix(in oklab,var(--color-white) 80%,transparent)}}.capitalize{text-transform:capitalize}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.underline{text-decoration-line:underline}.accent-\[\#6965db\]{accent-color:#6965db}.opacity-0{opacity:0}.opacity-25{opacity:.25}.opacity-45{opacity:.45}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-75{opacity:.75}.opacity-90{opacity:.9}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-2xl{--tw-shadow:0 25px 50px -12px var(--tw-shadow-color,#00000040);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_1px_4px_rgba\(0\,0\,0\,0\.25\)\]{--tw-shadow:0 1px 4px var(--tw-shadow-color,#00000040);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_2px_8px_rgba\(0\,0\,0\,0\.15\)\]{--tw-shadow:0 2px 8px var(--tw-shadow-color,#00000026);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_4px_16px_rgba\(0\,0\,0\,0\.15\)\]{--tw-shadow:0 4px 16px var(--tw-shadow-color,#00000026);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_4px_16px_rgba\(0\,0\,0\,0\.25\)\]{--tw-shadow:0 4px 16px var(--tw-shadow-color,#00000040);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[0_10px_30px_rgba\(36\,97\,255\,0\.20\)\]{--tw-shadow:0 10px 30px var(--tw-shadow-color,#2461ff33);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[var\(--shadow-md\)\]{--tw-shadow:var(--shadow-md);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[var\(--shadow-sm\)\]{--tw-shadow:var(--shadow-sm);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a), 0 8px 10px -6px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.invert{--tw-invert:invert(100%);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-100{--tw-duration:.1s;transition-duration:.1s}.duration-150{--tw-duration:.15s;transition-duration:.15s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}@media (hover:hover){.group-hover\:opacity-40:is(:where(.group):hover *){opacity:.4}.hover\:bg-\[var\(--surface-hover\)\]:hover{background-color:var(--surface-hover)}.hover\:bg-transparent:hover{background-color:#0000}.hover\:text-\[var\(--text-primary\)\]:hover{color:var(--text-primary)}.hover\:opacity-100:hover{opacity:1}}.active\:cursor-grabbing:active{cursor:grabbing}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-45:disabled{opacity:.45}@media (hover:hover){.disabled\:hover\:bg-transparent:disabled:hover{background-color:#0000}}}.material-symbols-outlined{letter-spacing:normal;text-transform:none;white-space:nowrap;word-wrap:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-feature-settings:"liga";font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 20;direction:ltr;font-family:Material Symbols;font-size:24px;font-style:normal;font-weight:400;line-height:1;display:inline-block}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{50%{opacity:.5}}.save-status{display:inline-flex;align-items:center;min-height:26px;padding:0 10px;border-radius:999px;font-size:var(--text-xs);color:var(--text-secondary);background:linear-gradient(180deg,#ffffff0a,#ffffff04);border:1px solid var(--border-subtle)}.user-badge{display:flex;align-items:center;gap:6px;font-size:var(--text-sm);color:var(--text-secondary);padding:4px 10px;border-radius:999px;background:linear-gradient(180deg,#ffffff0a,#ffffff04);border:1px solid var(--border-subtle)}.editor-topbar{position:relative;z-index:40;display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-4);height:54px;border-bottom:1px solid var(--border-subtle);background:linear-gradient(180deg,#ffffff0a,#ffffff04),var(--surface-floating);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 1px #ffffff08;flex-shrink:0}.editor-topbar-cluster{display:flex;align-items:center;gap:10px;min-width:0}.editor-topbar-meta{display:flex;align-items:center;gap:8px;min-width:0}.editor-brand-chip{display:inline-flex;align-items:center;gap:8px;height:34px;padding:0 12px 0 10px;border-radius:999px;background:linear-gradient(180deg,#ffffff0f,#ffffff05);border:1px solid var(--border-subtle);color:var(--text-primary);box-shadow:inset 0 1px #ffffff0a;white-space:nowrap}.editor-brand-mark{width:18px;height:18px;border-radius:6px;background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 45%,white));box-shadow:0 0 0 1px #ffffff14,0 8px 18px #2fd4c82e}.editor-brand-text{font-size:12px;font-weight:700;color:var(--text-primary)}.editor-document-rail{display:flex;align-items:center;gap:10px;min-width:0}.editor-topbar-title{display:inline-flex;align-items:center;height:34px;font-size:15px;font-weight:600;color:var(--text-primary);background:transparent;border:none;outline:none;padding:0 10px;border-radius:999px;min-width:120px;max-width:320px}.editor-topbar-title:hover{background:#ffffff0a}.editor-topbar-title:focus{background:#ffffff0a;box-shadow:0 0 0 1px var(--accent)}.editor-topbar-actions{display:flex;align-items:center;gap:8px}.editor-collaborators{display:flex;align-items:center;gap:6px;padding:0 8px;height:34px;border-radius:999px;border:1px solid var(--border-subtle);background:linear-gradient(180deg,#ffffff0a,#ffffff04)}.editor-collaborators-empty{font-size:11px;color:var(--text-muted);white-space:nowrap}.editor-topbar-actions .btn-icon{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:999px;color:var(--text-secondary);cursor:pointer;background:linear-gradient(180deg,#ffffff0a,#ffffff04);border:1px solid var(--border-subtle);transition:background .1s,color .1s}.editor-topbar-actions .btn-icon:hover{background:var(--surface-hover);color:var(--text-primary)}.canvas-stage{flex:1;display:flex;background:var(--surface-app);min-height:0;position:relative;padding:0}.canvas-viewport{position:relative;width:100%;height:100%;overflow:hidden;background:var(--surface-stage)}.editor-right-panel{width:var(--panel-width);min-width:var(--panel-width);border-left:1px solid var(--border-subtle);background:var(--surface-panel);display:flex;flex-direction:column;overflow:hidden}.editor-right-panel-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-subtle);font-size:var(--text-section-label);font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.editor-right-panel-section{padding:var(--space-4) var(--space-5)}.editor-right-panel-section+.editor-right-panel-section{margin-top:var(--space-1)}.editor-right-panel-section-title{font-size:var(--text-section-label);font-weight:500;color:var(--text-muted);margin-bottom:var(--space-3);text-transform:uppercase;letter-spacing:.05em}.editor-statusbar{display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);color:var(--text-secondary);flex-shrink:0;position:relative;background:transparent}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);display:flex;flex-direction:column;border-right:1px solid var(--border);background:var(--bg-primary)}.sidebar-section{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border)}.sidebar-section-title{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:var(--space-2)}.sidebar-list{list-style:none;overflow-y:auto;flex:1;padding:0;margin:0}.sidebar-item{padding:var(--space-2) var(--space-4);cursor:pointer;font-size:var(--text-sm);color:var(--text-secondary);transition:background .12s,color .12s}.sidebar-item:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-item.active{background:var(--bg-active);color:var(--text-primary);border-left:2px solid var(--accent)}.components-library{width:var(--components-library-width);min-width:var(--components-library-width);background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.library-header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border)}.library-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.library-header-row h3{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);margin:0}.library-actions{display:flex;gap:2px}.library-categories{display:flex;gap:4px;padding:var(--space-2) var(--space-4);overflow-x:auto;border-bottom:1px solid var(--border)}.library-categories button{padding:3px 10px;border-radius:var(--radius-full);border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:var(--text-xs);cursor:pointer;white-space:nowrap;transition:background .15s,color .15s,border-color .15s}.library-categories button:hover{color:var(--text-primary);border-color:var(--text-muted)}.library-categories button.active{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.library-empty{grid-column:1 / -1;color:var(--text-muted);font-size:var(--text-sm);text-align:center;padding:var(--space-8) var(--space-4)}.library-search{padding:var(--space-2) var(--space-4);border-bottom:1px solid var(--border)}.library-item-user{position:relative}.library-item-user.highlighted{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 15%,transparent);animation:highlight-pulse 2s ease-out}@keyframes highlight-pulse{0%{box-shadow:0 0 color-mix(in srgb,var(--accent) 40%,transparent)}50%{box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 20%,transparent)}to{box-shadow:0 0 color-mix(in srgb,var(--accent) 0%,transparent)}}.library-item-user.is-public,.library-item-user.is-public:hover{border-color:var(--green)}.publish-toggle{position:absolute;top:4px;right:4px;cursor:pointer;font-size:11px;opacity:.6;transition:opacity .15s;display:flex}.publish-toggle:hover{opacity:1}.delete-component-btn{position:absolute;top:4px;left:4px;border:none;background:transparent;cursor:pointer;font-size:11px;opacity:0;padding:2px;border-radius:var(--radius-sm);transition:opacity .15s}.library-item:hover .delete-component-btn{opacity:.6}.delete-component-btn:hover{opacity:1!important}.publish-btn{position:absolute;top:4px;right:4px;border:none;background:transparent;cursor:pointer;font-size:13px;padding:2px;border-radius:var(--radius-sm);color:var(--text-muted);transition:color .15s}.publish-btn:hover{color:var(--text-primary)}.library-item-user.is-public .publish-btn{color:var(--green)}.item-copy-info{font-size:9px;color:var(--text-muted);display:flex;align-items:center;gap:2px;line-height:1.2;margin-top:-2px}.public-item{position:relative}.item-author{font-size:var(--text-xs);color:var(--text-muted)}.copy-component-btn{padding:2px 8px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;color:var(--green);font-size:var(--text-xs);cursor:pointer;transition:background .15s}.copy-component-btn:hover{background:#10b9811a}.save-component-btn{position:absolute;top:8px;right:8px;z-index:100;padding:6px 12px;background:var(--accent);color:var(--accent-text);border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;cursor:pointer;box-shadow:var(--shadow-md)}.save-component-btn:hover{background:var(--accent-hover)}.version-history-btn{background:none;border:none;cursor:pointer;font-size:16px;padding:4px 8px;border-radius:var(--radius-md);color:var(--text-secondary);transition:background .15s,color .15s}.version-history-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.public-toggle{padding:var(--space-3) var(--space-4);border-top:1px solid var(--border)}.public-toggle label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:var(--text-sm);color:var(--text-secondary)}.public-toggle input[type=checkbox]{accent-color:var(--accent)}.share-link{display:flex;gap:4px;margin-top:var(--space-2)}.share-link input{flex:1;padding:4px 8px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--text-xs)}.online-users{position:absolute;top:8px;left:8px;z-index:100;display:flex;gap:4px}.btn-export{gap:4px}.export-dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:100;min-width:200px;overflow:hidden}.export-dropdown button{display:flex;align-items:center;gap:8px;width:100%;padding:8px 14px;border:none;background:transparent;color:var(--text-primary);font-size:var(--text-sm);cursor:pointer;text-align:left;transition:background .1s}.export-dropdown button:hover{background:var(--bg-hover)}.export-options-group{display:flex;flex-direction:column;gap:var(--space-3);margin:var(--space-4) 0}.export-option-label{display:inline-flex;align-items:center;gap:6px;font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;padding:4px 10px;border:1px solid var(--border);border-radius:var(--radius-md);transition:border-color .15s,background .15s}.export-option-label:hover{border-color:var(--accent)}.export-option-label input[type=radio],.export-option-label input[type=checkbox]{accent-color:var(--accent)}.api-key-warning{color:var(--red);font-size:var(--text-xs);padding:var(--space-3);border-radius:var(--radius-md);margin-bottom:var(--space-2);background:#ef44441a;border:1px solid rgba(239,68,68,.2)}[data-panel]{transition:left .2s cubic-bezier(.2,.9,.4,1.1),top .2s cubic-bezier(.2,.9,.4,1.1)}[data-panel]:active{transition:none}.sticking{border-left:2px solid var(--accent)}.stick-indicator{position:absolute;left:-6px;top:50%;transform:translateY(-50%);width:4px;height:16px;border-radius:2px;background:var(--accent);opacity:.6;pointer-events:none}[data-panel]:active .stick-indicator{opacity:0}
