:root{--color-accent:#7c3aed;--color-accent-hover:#8b5cf6;--color-accent-subtle:#7c3aed1f;--color-accent-glow:#7c3aed40;--color-bg-deep:#09090b;--color-bg:#0f0f11;--color-surface:#ffffff08;--color-surface-solid:#161618;--color-surface-raised:#ffffff0d;--color-surface-hover:#ffffff12;--color-border:#ffffff12;--color-border-strong:#ffffff1f;--color-text:#ececee;--color-text-secondary:#a1a1a5;--color-text-muted:#52525a;--color-danger:#f43f5e;--color-danger-subtle:#f43f5e1f;--glass:#161618bf;--glass-border:#ffffff0f;--glass-blur:blur(20px) saturate(180%);--radius:10px;--radius-sm:6px;--radius-lg:14px;--shadow:0 0 0 1px var(--glass-border), 0 8px 40px #0006;--shadow-sm:0 0 0 1px var(--glass-border), 0 2px 8px #0000004d;--shadow-glow:0 0 24px var(--color-accent-glow);--transition:.18s ease;--transition-slow:.3s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"cv02", "cv03", "cv04", "cv11";font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden}#root{height:100vh}::selection{background:var(--color-accent-subtle);color:var(--color-text)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff24}.app{background:var(--color-bg);flex-direction:column;height:100%;display:flex}.main-content{flex:1;display:flex;position:relative;overflow:hidden}.top-bar{background:var(--glass);height:52px;-webkit-backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--color-border);z-index:100;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 16px;display:flex}.top-bar-left{align-items:center;gap:10px;display:flex}.app-title{color:var(--color-text);letter-spacing:-.01em;font-size:14px;font-weight:600}.unsaved-indicator{color:var(--color-accent);font-size:20px;line-height:1;animation:2s ease-in-out infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.top-bar-center{align-items:center;display:flex;position:absolute;left:50%;transform:translate(-50%)}.top-bar-right{align-items:center;gap:6px;display:flex}.mode-toggle{background:var(--color-surface);border:1px solid var(--color-border);border-radius:9999px;padding:3px;display:flex}.mode-btn{color:var(--color-text-muted);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:9999px;align-items:center;gap:5px;padding:5px 16px;font-family:inherit;font-size:12px;font-weight:500;display:inline-flex}.mode-btn.active{background:var(--color-accent);color:#fff;box-shadow:0 0 12px var(--color-accent-glow)}.mode-btn:hover:not(.active){color:var(--color-text-secondary)}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);white-space:nowrap;letter-spacing:-.01em;border:none;align-items:center;gap:6px;padding:7px 14px;font-family:inherit;font-size:12px;font-weight:500;display:inline-flex}.btn-primary{background:var(--color-accent);color:#fff;box-shadow:0 0 16px #7c3aed33}.btn-primary:hover{background:var(--color-accent-hover);box-shadow:0 0 24px #7c3aed4d}.btn-secondary{background:var(--color-surface-raised);color:var(--color-text-secondary);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-surface-hover);color:var(--color-text);border-color:var(--color-border-strong)}.btn-ghost{color:var(--color-text-secondary);background:0 0}.btn-ghost:hover{background:var(--color-surface-hover);color:var(--color-text)}.btn-sm{background:var(--color-accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);border:none;align-items:center;gap:4px;padding:4px 10px;font-family:inherit;font-size:11px;font-weight:500;display:inline-flex}.btn-sm:hover{background:var(--color-accent-hover)}.btn-icon{border-radius:var(--radius-sm);cursor:pointer;width:28px;height:28px;color:var(--color-text-muted);transition:all var(--transition);background:0 0;border:none;justify-content:center;align-items:center;font-size:13px;display:inline-flex}.btn-icon:hover{background:var(--color-surface-hover);color:var(--color-text)}.btn-icon:disabled{opacity:.25;cursor:default}.btn-icon:disabled:hover{color:var(--color-text-muted);background:0 0}.btn-danger-icon:hover{background:var(--color-danger-subtle);color:var(--color-danger)}.empty-state{background:var(--color-bg-deep);flex:1;justify-content:center;align-items:center;display:flex}.empty-state-content{text-align:center;max-width:420px}.empty-state-icon{color:var(--color-text-muted);opacity:.5;margin-bottom:20px}.empty-state-content h2{letter-spacing:-.02em;background:linear-gradient(to bottom, var(--color-text), var(--color-text-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:22px;font-weight:600}.empty-state-content>p{color:var(--color-text-muted);margin-bottom:28px;font-size:14px;line-height:1.5}.empty-state-actions{justify-content:center;align-items:center;gap:12px;display:flex}.empty-state-divider{color:var(--color-text-muted);font-size:12px}.empty-state-hint{color:var(--color-text-muted);opacity:.6;font-size:12px;margin-top:20px!important;margin-bottom:0!important}.canvas-wrapper{background:var(--color-bg-deep);background-image:radial-gradient(circle,#ffffff08 1px,#0000 1px);background-size:24px 24px;flex:1;position:relative;overflow:hidden}.canvas-transform{transform-origin:0 0;will-change:transform}.canvas-container{-webkit-user-select:none;user-select:none;border-radius:4px;position:relative;overflow:visible;box-shadow:0 0 0 1px #ffffff0a,0 20px 60px #00000080}.canvas-wrapper.mode-editor .canvas-container{cursor:crosshair}.canvas-image{pointer-events:none;border-radius:4px;width:100%;height:100%;display:block}.canvas-wrapper.space-held,.canvas-wrapper.space-held .canvas-container,.canvas-wrapper.space-held .sel-overlay,.canvas-wrapper.space-held .resize-handle,.canvas-wrapper.space-held .hotspot{cursor:grab!important}.zoom-controls{background:var(--glass);-webkit-backdrop-filter:var(--glass-blur);border-radius:var(--radius);border:1px solid var(--color-border);z-index:50;align-items:center;gap:1px;padding:3px;display:flex;position:absolute;bottom:16px;right:16px}.zoom-btn{border-radius:var(--radius-sm);cursor:pointer;width:30px;height:26px;color:var(--color-text-muted);transition:all var(--transition);background:0 0;border:none;justify-content:center;align-items:center;font-size:14px;display:flex}.zoom-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}.zoom-level{color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);text-align:center;font-variant-numeric:tabular-nums;background:0 0;border:none;min-width:44px;padding:4px 6px;font-family:inherit;font-size:11px;font-weight:500}.zoom-level:hover{background:var(--color-surface-hover);color:var(--color-text)}.zoom-divider{background:var(--color-border);width:1px;height:16px;margin:0 2px}.sel-overlay{cursor:grab;transition:box-shadow var(--transition);border:1.5px solid;position:absolute}.sel-overlay:hover{box-shadow:0 0 0 1px #ffffff1a}.sel-selected{box-shadow:0 0 16px var(--color-accent-glow)}.sel-badge{color:#fff;border-radius:0 0 var(--radius-sm) 0;white-space:nowrap;text-overflow:ellipsis;pointer-events:none;letter-spacing:.02em;text-transform:uppercase;max-width:120px;padding:1px 6px;font-size:9px;font-weight:600;line-height:1.6;position:absolute;top:-1px;left:-1px;overflow:hidden}.resize-handle{background:var(--color-bg);z-index:20;border:2px solid;border-radius:2px;width:9px;height:9px;position:absolute}.rh-nw{top:-5px;left:-5px}.rh-n{top:-5px;left:50%;transform:translate(-50%)}.rh-ne{top:-5px;right:-5px}.rh-w{top:50%;left:-5px;transform:translateY(-50%)}.rh-e{top:50%;right:-5px;transform:translateY(-50%)}.rh-sw{bottom:-5px;left:-5px}.rh-s{bottom:-5px;left:50%;transform:translate(-50%)}.rh-se{bottom:-5px;right:-5px}.drawing-preview{border:1.5px dashed var(--color-accent);background:var(--color-accent-subtle);pointer-events:none;z-index:50;position:absolute}.hotspot{cursor:pointer;border:1px dashed color-mix(in srgb, var(--hotspot-color) 35%, transparent);background:color-mix(in srgb, var(--hotspot-color) 5%, transparent);border-radius:3px;transition:all .25s;position:absolute}.hotspot-hovered{background:color-mix(in srgb, var(--hotspot-color) 14%, transparent);border:1.5px solid color-mix(in srgb, var(--hotspot-color) 55%, transparent);box-shadow:0 0 20px color-mix(in srgb, var(--hotspot-color) 22%, transparent), inset 0 0 20px color-mix(in srgb, var(--hotspot-color) 6%, transparent)}.viewer-tooltip{background:var(--glass);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--color-border-strong);border-radius:var(--radius);box-shadow:var(--shadow), 0 0 20px #0000004d;z-index:100;pointer-events:auto;min-width:200px;max-width:320px;padding:12px;position:absolute;left:50%;transform:translate(-50%)}.vt-above{bottom:calc(100% + 10px)}.vt-below{top:calc(100% + 10px)}.viewer-tooltip:after{content:"";border:6px solid #0000;position:absolute;left:50%;transform:translate(-50%)}.vt-above:after{border-top-color:#ffffff14;top:100%}.vt-below:after{border-bottom-color:#ffffff14;bottom:100%}.vt-title{color:var(--color-text);border-bottom:1px solid var(--color-border);letter-spacing:-.01em;margin-bottom:8px;padding-bottom:8px;font-size:12px;font-weight:600}.vt-links{flex-direction:column;gap:2px;max-height:200px;display:flex;overflow-y:auto}.vt-link{color:#c4b5fd;border-radius:var(--radius-sm);transition:all var(--transition);align-items:center;gap:6px;padding:5px 8px;font-size:12px;text-decoration:none;display:flex}.vt-link-text{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.vt-link svg{opacity:.5;transition:opacity var(--transition);flex-shrink:0}.vt-link:hover svg{opacity:1}.vt-link:hover{background:var(--color-accent-subtle);color:#e9e0ff}.side-panel{background:var(--glass);width:300px;-webkit-backdrop-filter:var(--glass-blur);border-left:1px solid var(--color-border);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.sp-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.sp-header-title{color:var(--color-text-secondary);align-items:center;gap:7px;display:flex}.sp-header h2{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:600}.sp-list{flex:1;padding:6px;overflow-y:auto}.sp-empty{text-align:center;color:var(--color-text-muted);padding:32px 16px;font-size:12px;line-height:1.5}.sp-item{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);border:1px solid #0000;align-items:center;gap:10px;padding:8px 10px;display:flex}.sp-item:hover{background:var(--color-surface-hover);border-color:var(--color-border)}.sp-item-active{background:var(--color-accent-subtle);border-color:#7c3aed33}.sp-item-active:hover{background:var(--color-accent-subtle);border-color:#7c3aed4d}.sp-item-color{border-radius:3px;flex-shrink:0;width:10px;height:10px;box-shadow:0 0 6px}.sp-item-info{flex:1;min-width:0}.sp-item-name{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:500;display:block;overflow:hidden}.sp-item-meta{color:var(--color-text-muted);align-items:center;gap:4px;margin-top:1px;font-size:11px;display:flex}.link-editor{border-top:1px solid var(--color-border);max-height:50%;padding:14px;overflow-y:auto}.le-field{margin-bottom:14px}.le-field label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:5px;font-size:11px;font-weight:500;display:block}.le-field input,.le-link-item input{border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text);transition:border-color var(--transition), box-shadow var(--transition), background var(--transition);background:#0003;outline:none;padding:7px 10px;font-family:inherit;font-size:12px}.le-field input::placeholder,.le-link-item input::placeholder{color:var(--color-text-muted)}.le-field input:focus,.le-link-item input:focus{box-shadow:0 0 0 3px var(--color-accent-subtle);background:#0000004d;border-color:#7c3aed80}.input-error{border-color:var(--color-danger)!important;box-shadow:0 0 0 3px var(--color-danger-subtle)!important}.le-links-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.le-links-header h3{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:600}.le-links{flex-direction:column;gap:6px;display:flex}.le-empty{color:var(--color-text-muted);text-align:center;padding:16px 0;font-size:12px}.le-link-item{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#00000026;flex-direction:column;gap:4px;padding:8px;display:flex}.le-link-actions{justify-content:flex-end;gap:2px;margin-top:2px;display:flex}.side-panel-toggle{background:var(--glass);width:34px;height:34px;-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text-muted);transition:all var(--transition);z-index:20;justify-content:center;align-items:center;font-size:14px;display:flex;position:absolute;top:12px;right:12px}.side-panel-toggle:hover{background:var(--color-surface-hover);color:var(--color-text);border-color:var(--color-border-strong)}.dialog-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;animation:.15s dialog-fade-in;display:flex;position:fixed;inset:0}@keyframes dialog-fade-in{0%{opacity:0}to{opacity:1}}@keyframes dialog-slide-in{0%{opacity:0;transform:scale(.96)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.dialog-card{background:var(--color-surface-solid);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);width:100%;max-width:400px;box-shadow:0 24px 80px #00000080, 0 0 0 1px var(--glass-border);animation:.2s dialog-slide-in;overflow:hidden}.dialog-header{align-items:center;gap:10px;padding:16px 16px 0;display:flex}.dialog-icon{border-radius:var(--radius-sm);background:var(--color-surface-hover);width:32px;height:32px;color:var(--color-text-secondary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.dialog-icon-danger{background:var(--color-danger-subtle);color:var(--color-danger)}.dialog-icon-accent{background:var(--color-accent-subtle);color:var(--color-accent-hover)}.dialog-title{color:var(--color-text);letter-spacing:-.01em;flex:1;font-size:14px;font-weight:600}.dialog-close{flex-shrink:0}.dialog-message{color:var(--color-text-secondary);padding:10px 16px 0;font-size:13px;line-height:1.5}.dialog-body{padding:12px 16px 0}.dialog-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:5px;font-size:11px;font-weight:500;display:block}.dialog-input-group{border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:border-color var(--transition), box-shadow var(--transition);background:#0003;align-items:center;display:flex}.dialog-input-group:focus-within{box-shadow:0 0 0 3px var(--color-accent-subtle);border-color:#7c3aed80}.dialog-input{min-width:0;color:var(--color-text);background:0 0;border:none;outline:none;flex:1;padding:8px 10px;font-family:inherit;font-size:13px}.dialog-input::placeholder{color:var(--color-text-muted)}.dialog-input-suffix{color:var(--color-text-muted);-webkit-user-select:none;user-select:none;white-space:nowrap;padding:0 10px 0 0;font-size:13px}.dialog-actions{justify-content:flex-end;gap:8px;padding:16px;display:flex}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{background:#e11d48}.btn:disabled{opacity:.4;cursor:default;pointer-events:none}.top-bar-divider{background:var(--color-border);flex-shrink:0;width:1px;height:20px;margin:0 2px}.settings-card{background:var(--color-surface-solid);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);width:100%;max-width:480px;box-shadow:0 24px 80px #00000080, 0 0 0 1px var(--glass-border);animation:.2s dialog-slide-in;overflow:hidden}.settings-header{justify-content:space-between;align-items:center;padding:16px 16px 0;display:flex}.settings-header-title{color:var(--color-text);align-items:center;gap:8px;display:flex}.settings-header-title h2{letter-spacing:-.01em;font-size:14px;font-weight:600}.settings-body{padding:16px}.settings-section{border:1px solid var(--color-border);border-radius:var(--radius);background:#00000026;padding:14px}.settings-section-header{justify-content:space-between;align-items:flex-start;margin-bottom:14px;display:flex}.settings-section-header h3{color:var(--color-text);margin-bottom:2px;font-size:12px;font-weight:600}.settings-section-header p{color:var(--color-text-muted);font-size:11px;line-height:1.4}.btn-xs{padding:3px 8px;font-size:11px}.palette-grid{flex-wrap:wrap;gap:8px;display:flex}.palette-swatch-wrapper{position:relative}.palette-swatch{border-radius:var(--radius-sm);cursor:pointer;width:36px;height:36px;transition:all var(--transition);border:2px solid #0000;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #ffffff1a}.palette-swatch:hover{border-color:#ffffff4d;transform:scale(1.1);box-shadow:0 0 12px}.palette-swatch-input{opacity:0;cursor:pointer;border:none;width:100%;height:100%;padding:0;position:absolute;inset:0}.palette-swatch-remove{background:var(--color-danger);color:#fff;cursor:pointer;opacity:0;width:16px;height:16px;transition:opacity var(--transition);z-index:2;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:-6px;right:-6px}.palette-swatch-wrapper:hover .palette-swatch-remove{opacity:1}.palette-add{border:1.5px dashed var(--color-border-strong);border-radius:var(--radius-sm);width:36px;height:36px;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition);background:0 0;justify-content:center;align-items:center;display:flex}.palette-add:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-subtle)}.le-color-row{gap:10px;margin-bottom:14px;display:flex}.le-field-grow{flex:1;min-width:0;margin-bottom:0}.le-field-color{flex-shrink:0;margin-bottom:0}.le-color-picker{align-items:center;gap:4px;display:flex}.le-color-swatch{border-radius:var(--radius-sm);cursor:pointer;width:30px;height:30px;transition:all var(--transition);border:2px solid #0000;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #ffffff1a}.le-color-swatch:hover{border-color:#ffffff4d;box-shadow:0 0 10px}.le-color-input{opacity:0;cursor:pointer;border:none;width:100%;height:100%;padding:0;position:absolute;inset:0}.le-color-reset{color:var(--color-text-muted);width:22px!important;height:22px!important}.le-color-reset:hover{color:var(--color-text)}
