:root{--bg: #0e0e12;--surface: #16161d;--surface2: #1e1e28;--border: #2a2a38;--text: #e8e8f0;--text-muted: #7a7a9a;--accent: #7c3aed;--accent-hover: #6d28d9;--accent-soft: rgba(124, 58, 237, .12);--color-deep: #0c070f;--color-dark: #150a1a;--color-base: #1a0f20;--color-medium: #2a1530;--color-accent: #3a2540;--color-gradient-1: #4a2560;--color-gradient-2: #5a3570;--color-gradient-3: #6a3590;--color-gradient-4: #7a45a0;--color-text: #c8b8d8;--color-text-light: #cdb7e4;--color-orange: #e7762b;--color-orange-dark: #d66420;--color-white: #ffffff;--color-black: #000000;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--color-error-dark: #dc2626;--color-surface: var(--surface);--color-surface-elevated: var(--surface2);--color-border: var(--border);--color-text-primary: var(--text);--color-text-secondary: var(--text-muted);--color-primary: var(--accent);--color-primary-dark: var(--accent-hover);--color-danger: var(--color-error);--color-danger-dark: var(--color-error-dark);--gradient-primary: linear-gradient(135deg, #4a2560 0%, #7a45a0 100%);--gradient-secondary: linear-gradient(135deg, #e7762b 0%, #f59e0b 100%);--gradient-hero: linear-gradient(135deg, #0c070f 0%, #2a1530 50%, #4a2560 100%);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--spacing-4xl: 6rem;--spacing-5xl: 8rem;--spacing-responsive-sm: clamp(.5rem, 2vw, 1rem);--spacing-responsive-md: clamp(1rem, 4vw, 2rem);--spacing-responsive-lg: clamp(1.5rem, 6vw, 3rem);--spacing-responsive-xl: clamp(2rem, 8vw, 4rem);--font-size-xs: clamp(.75rem, 2vw, .875rem);--font-size-sm: clamp(.875rem, 2.5vw, 1rem);--font-size-md: clamp(1rem, 3vw, 1.125rem);--font-size-lg: clamp(1.125rem, 3.5vw, 1.25rem);--font-size-xl: clamp(1.25rem, 4vw, 1.5rem);--font-size-2xl: clamp(1.5rem, 5vw, 2rem);--font-size-3xl: clamp(2rem, 6vw, 3rem);--font-primary: "Poppins", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "Fira Code", "JetBrains Mono", "SF Mono", Consolas, monospace;--size-xs: clamp(1rem, 3vw, 1.5rem);--size-sm: clamp(1.5rem, 4vw, 2rem);--size-md: clamp(2rem, 5vw, 2.5rem);--size-lg: clamp(2.5rem, 6vw, 3rem);--size-xl: clamp(3rem, 8vw, 4rem);--container-xs: min(90vw, 20rem);--container-sm: min(90vw, 30rem);--container-md: min(90vw, 40rem);--container-lg: min(90vw, 60rem);--container-xl: min(95vw, 80rem);--container-2xl: min(95vw, 100rem);--sidebar-width: clamp(16rem, 25vw, 22rem);--sidebar-collapsed: clamp(3rem, 8vw, 4rem);--properties-panel-width: clamp(18rem, 22vw, 22rem);--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--border-radius: var(--radius-md);--border-radius-lg: var(--radius-lg);--shadow-sm: 0 .0625rem .125rem 0 rgba(0, 0, 0, .05);--shadow-md: 0 .25rem .375rem -.0625rem rgba(0, 0, 0, .1), 0 .125rem .25rem -.0625rem rgba(0, 0, 0, .06);--shadow-lg: 0 .625rem .9375rem -.1875rem rgba(0, 0, 0, .1), 0 .25rem .375rem -.125rem rgba(0, 0, 0, .05);--shadow-xl: 0 1.25rem 1.5625rem -.3125rem rgba(0, 0, 0, .1), 0 .625rem .625rem -.3125rem rgba(0, 0, 0, .04);--shadow-purple: 0 .625rem .9375rem -.1875rem rgba(106, 53, 144, .3), 0 .25rem .375rem -.125rem rgba(106, 53, 144, .15);--shadow-orange: 0 .625rem .9375rem -.1875rem rgba(231, 118, 43, .3), 0 .25rem .375rem -.125rem rgba(231, 118, 43, .15);--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease}*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}body{font-family:var(--font-primary);background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}.app{display:flex;flex-direction:column;min-height:100vh;background:var(--bg)}.main-content{display:flex;flex:1;height:calc(100vh - var(--size-lg));overflow:hidden;transition:all var(--transition-normal)}::-webkit-scrollbar{width:.5rem;height:.5rem}::-webkit-scrollbar-track{background:var(--surface)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.topbar{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:.875rem 1.5rem;background:var(--surface);border-bottom:.0625rem solid var(--border);position:sticky;top:0;z-index:100}.topbar-brand{display:inline-flex;align-items:center;gap:.625rem;text-decoration:none;min-width:0}.topbar-logo{height:2.25rem;width:auto;display:block;object-fit:contain;filter:brightness(1.05)}.topbar-name{font-weight:700;font-size:.9375rem;color:var(--text);white-space:nowrap}.topbar-tool{font-size:.8125rem;color:var(--text-muted);padding-left:.625rem;border-left:.0625rem solid var(--border);margin-left:.375rem;white-space:nowrap}.sinapsialab-gradient-link{color:transparent;background:linear-gradient(90deg,#ec4899,#facc15,#3b82f6);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;text-decoration:none;font-weight:700;position:relative;filter:drop-shadow(0 .0625rem .5rem rgba(236,72,153,.2))}.sinapsialab-gradient-link:after{content:"";position:absolute;left:0;right:0;bottom:-.125rem;height:.0625rem;background:linear-gradient(90deg,#ec4899,#facc15,#3b82f6);opacity:0;transition:opacity .2s}.topbar-brand:hover .sinapsialab-gradient-link:after{opacity:1}.topbar-project{display:inline-flex;align-items:center;gap:.5rem;margin-left:.875rem;padding-left:.875rem;border-left:.0625rem solid var(--border);min-width:0}.topbar-project-title{font-size:.8125rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:18rem}.topbar-project-stats{font-size:.75rem;color:var(--text-muted);white-space:nowrap}.topbar-actions{display:inline-flex;align-items:center;gap:.625rem;flex-wrap:wrap;justify-content:flex-end}.btn{display:inline-flex;align-items:center;gap:.4375rem;padding:.5rem 1rem;border-radius:var(--radius-sm);font-size:.8125rem;font-weight:600;font-family:inherit;cursor:pointer;border:.0625rem solid transparent;background:transparent;color:var(--text-muted);text-decoration:none;line-height:1;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast)}.btn svg{flex-shrink:0}.btn-ghost{background:transparent;color:var(--text-muted);border-color:var(--border)}.btn-ghost:hover{color:var(--text);border-color:var(--text-muted)}.btn-primary{background:var(--accent);color:var(--color-white);border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);transform:translateY(-.0625rem)}.btn-danger{background:transparent;color:var(--color-error);border-color:#ef444466}.btn-danger:hover{background:var(--color-error);border-color:var(--color-error);color:var(--color-white)}.sidebar{width:var(--sidebar-width);background:var(--surface);border-right:.0625rem solid var(--border);display:flex;flex-direction:column;overflow:hidden;transition:width var(--transition-normal)}.sidebar-header{padding:var(--spacing-lg);border-bottom:.0625rem solid var(--border)}.sidebar-header h3{font-size:.6875rem;font-weight:700;letter-spacing:.075rem;text-transform:uppercase;color:var(--text-muted);margin-bottom:var(--spacing-xs)}.sidebar-header p{font-size:var(--font-size-sm);color:var(--text)}.categories{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);padding:var(--spacing-md);border-bottom:.0625rem solid var(--border)}.category-button{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--surface2);border:.0625rem solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:var(--font-size-xs);font-family:inherit;cursor:pointer;transition:all var(--transition-fast);line-height:1}.category-button svg{flex:none}.category-button:hover{background:var(--surface);color:var(--text);border-color:var(--text-muted)}.category-button.active{background:var(--accent);color:var(--color-white);border-color:var(--accent)}.templates-list{flex:1;overflow-y:auto;padding:var(--spacing-md)}.template-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--surface2);border:.0625rem solid var(--border);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm);cursor:pointer;transition:all var(--transition-fast)}.template-item:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-.0625rem)}.template-icon{display:inline-flex;align-items:center;justify-content:center;min-width:2.5rem;width:2.5rem;height:2.5rem;border-radius:var(--radius-sm);background:var(--accent-soft);color:var(--accent)}.template-item:hover .template-icon{color:var(--accent)}.template-info{flex:1;min-width:0}.template-name{font-size:.8125rem;font-weight:600;color:var(--text);margin-bottom:.125rem}.template-description{font-size:.75rem;color:var(--text-muted);line-height:1.4}.template-action{display:inline-flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;background:var(--accent);color:var(--color-white);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.template-item:hover .template-action{background:var(--accent-hover)}.sidebar-footer{padding:var(--spacing-md);border-top:.0625rem solid var(--border)}.templates-info{margin-bottom:var(--spacing-sm)}.templates-info small{color:var(--text-muted)}.sinapsialab-branding{text-align:center}.branding-link{display:flex;flex-direction:column;align-items:center;gap:.125rem;color:var(--text-muted);text-decoration:none;font-size:.75rem;transition:color var(--transition-fast)}.branding-link strong{font-weight:700;background:linear-gradient(90deg,#ec4899,#facc15,#3b82f6);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 .0625rem .5rem rgba(236,72,153,.2))}.canvas-area{flex:1;display:flex;flex-direction:column;background:var(--bg);overflow:hidden}.canvas-header{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.5rem;background:var(--surface);border-bottom:.0625rem solid var(--border)}.canvas-title h2{font-size:.6875rem;font-weight:700;letter-spacing:.075rem;text-transform:uppercase;color:var(--text-muted);margin-bottom:.25rem}.section-count{font-size:var(--font-size-sm);color:var(--text)}.canvas-actions{display:flex;gap:.625rem}.canvas-button{display:inline-flex;align-items:center;gap:.4375rem;padding:.5rem 1rem;border:.0625rem solid transparent;border-radius:var(--radius-sm);font-size:.8125rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--transition-fast);line-height:1}.canvas-button svg{flex:none}.canvas-button.primary{background:var(--accent);color:var(--color-white);border-color:var(--accent)}.canvas-button.primary:not(:disabled):hover{background:var(--accent-hover);border-color:var(--accent-hover);transform:translateY(-.0625rem)}.canvas-button.secondary{background:transparent;color:var(--text-muted);border-color:var(--border)}.canvas-button.secondary:not(:disabled):hover{color:var(--text);border-color:var(--text-muted)}.canvas-button:disabled{opacity:.5;cursor:not-allowed}.canvas{flex:1;background:var(--color-white);overflow-y:auto;position:relative;transition:all var(--transition-normal);min-width:25rem}.main-content.with-properties .canvas{max-width:calc(100vw - 43.75rem);min-width:21.875rem}.canvas.drag-over{background:#f0f9ff;border:.125rem dashed var(--accent)}.canvas.can-drop{box-shadow:inset 0 0 1.25rem #7c3aed1a}.empty-canvas{display:flex;align-items:center;justify-content:center;height:100%;padding:var(--spacing-3xl);position:relative}.empty-canvas-content{text-align:center;max-width:31.25rem}.empty-icon{display:inline-flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-lg);color:var(--accent)}.empty-canvas h3{font-size:var(--font-size-2xl);color:#0f172a;margin-bottom:var(--spacing-md)}.empty-canvas p{color:#64748b;margin-bottom:var(--spacing-xl);line-height:1.6}.empty-suggestions{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:#f8fafc;border:.0625rem solid #e2e8f0;border-radius:var(--radius-md);color:#475569;font-size:var(--font-size-sm)}.empty-suggestions svg{color:var(--accent);flex:none}.drop-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--accent);color:var(--color-white);padding:var(--spacing-lg) var(--spacing-xl);border-radius:var(--radius-xl);font-weight:600;box-shadow:0 1.25rem 1.5625rem -.3125rem #7c3aed59}.global-drop-indicator{position:absolute;bottom:var(--spacing-lg);left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);color:var(--accent);font-weight:500}.drop-line{width:12.5rem;height:.125rem;background:var(--accent);border-radius:.0625rem}.section-wrapper{position:relative;margin:0}.section-wrapper.selected{outline:.125rem solid var(--accent);outline-offset:.25rem}.section-container{position:relative}.section-toolbar{position:absolute;top:0;left:0;right:0;background:var(--surface);border:.0625rem solid var(--border);border-radius:var(--radius-sm);padding:var(--spacing-sm) var(--spacing-md);display:flex;align-items:center;justify-content:space-between;z-index:150;-webkit-backdrop-filter:blur(.625rem);backdrop-filter:blur(.625rem);box-shadow:var(--shadow-lg);transform:translateY(-100%);margin-top:-.25rem}.section-info{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--text-muted);font-size:var(--font-size-sm)}.section-icon{display:inline-flex;align-items:center;justify-content:center;color:var(--accent)}.section-name{font-weight:600;color:var(--text)}.section-index{background:var(--accent);color:var(--color-white);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:600}.section-actions{display:flex;gap:var(--spacing-xs)}.section-action-btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-xs);min-width:1.75rem;height:1.75rem;background:transparent;border:.0625rem solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-fast)}.section-action-btn svg{flex:none}.section-action-btn:hover{background:var(--surface2);color:var(--text);border-color:var(--text-muted)}.section-action-btn:disabled{opacity:.5;cursor:not-allowed}.section-action-btn.danger:hover{background:var(--color-error);border-color:var(--color-error);color:var(--color-white)}.section-content{position:relative;background:var(--color-white)}.section-error{padding:var(--spacing-xl);background:#fef2f2;border:.0625rem solid #fecaca;border-radius:var(--radius-md);color:#dc2626;text-align:center}.selection-indicator{position:absolute;inset:0;border:.125rem solid var(--accent);border-radius:var(--radius-md);pointer-events:none;background:#7c3aed0d}.properties-panel{width:var(--properties-panel-width);background:var(--surface);border-left:.0625rem solid var(--border);overflow-y:auto;transition:width var(--transition-normal);display:flex;flex-direction:column}.properties-empty{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl)}.properties-empty-content{text-align:center;color:var(--text-muted)}.properties-empty-content .empty-icon{display:inline-flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-md);color:var(--accent)}.properties-empty-content h3{color:var(--text);font-size:var(--font-size-lg);margin-bottom:var(--spacing-sm)}.properties-empty-content p{font-size:var(--font-size-sm);line-height:1.5}.properties-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:.0625rem solid var(--border);background:var(--surface);position:sticky;top:0;z-index:1}.properties-header h3{color:var(--text-muted);font-size:.6875rem;font-weight:700;letter-spacing:.075rem;text-transform:uppercase}.section-type{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--accent-soft);color:var(--accent);border:.0625rem solid rgba(124,58,237,.35);border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.section-type svg{flex:none}.properties-content{padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.property-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.property-group label,.property-label{display:flex;flex-direction:column;gap:.375rem;font-size:.8125rem;font-weight:600;color:var(--text)}.property-input,.property-textarea,.property-select{width:100%;padding:.5625rem .75rem;background:var(--surface2);border:.0625rem solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.8125rem;font-family:inherit;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.property-input::placeholder,.property-textarea::placeholder{color:var(--text-muted)}.property-input:focus,.property-textarea:focus,.property-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 .1875rem var(--accent-soft)}.property-textarea{resize:vertical;min-height:4.375rem;line-height:1.5}.property-input[type=color]{height:2.5rem;padding:.25rem;cursor:pointer}.property-button{display:inline-flex;align-items:center;justify-content:center;gap:.4375rem;width:100%;padding:.5rem 1rem;background:transparent;border:.0625rem solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.8125rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--transition-fast);line-height:1}.property-button svg{flex:none}.property-button:hover{background:var(--surface2);color:var(--text);border-color:var(--text-muted)}.property-button.danger{border-color:#ef444466;color:var(--color-error)}.property-button.danger:hover{background:var(--color-error);border-color:var(--color-error);color:var(--color-white)}.property-button.small{width:auto;padding:var(--spacing-xs) .5rem;font-size:var(--font-size-xs);min-width:1.75rem;min-height:1.75rem}.property-checkbox{display:inline-flex;align-items:center;gap:var(--spacing-xs);cursor:pointer}.property-description{display:block;margin-top:.25rem;font-size:var(--font-size-xs);color:var(--text-muted);line-height:1.4}.property-array{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-sm);background:#ffffff05;border:.0625rem dashed var(--border);border-radius:var(--radius-sm)}.property-array-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm)}.property-label-text{font-size:.8125rem;font-weight:600;color:var(--text)}.property-array-empty{font-size:var(--font-size-xs);color:var(--text-muted);text-align:center;padding:var(--spacing-sm)}.property-array-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.property-array-item{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--surface2);border:.0625rem solid var(--border);border-radius:var(--radius-sm)}.property-array-item-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-xs)}.property-array-item-title{font-size:var(--font-size-xs);font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:.03125rem}.property-array-item-actions{display:flex;gap:var(--spacing-xs)}.property-array-item-body{display:flex;flex-direction:column;gap:var(--spacing-sm)}.preview-modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0e0e12d9;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(.25rem);backdrop-filter:blur(.25rem)}.preview-content{background:var(--surface);width:95%;height:95%;border-radius:var(--radius-md);overflow:hidden;display:flex;flex-direction:column;box-shadow:0 1.25rem 2.5rem #00000073;border:.0625rem solid var(--border)}.preview-header{padding:.875rem 1.5rem;background:var(--surface);border-bottom:.0625rem solid var(--border);display:flex;justify-content:space-between;align-items:center}.preview-header h3{margin:0;color:var(--text-muted);font-size:.6875rem;font-weight:700;letter-spacing:.075rem;text-transform:uppercase}.preview-controls{display:flex;gap:.625rem;align-items:center;flex-wrap:wrap}.preview-controls .action-button{background:transparent;color:var(--text-muted);border:.0625rem solid var(--border);padding:.5rem 1rem;border-radius:var(--radius-sm);font-size:.8125rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--transition-fast);display:inline-flex;align-items:center;gap:.4375rem;line-height:1}.preview-controls .action-button svg{flex:none}.preview-controls .action-button.secondary:hover:not(:disabled){color:var(--text);border-color:var(--text-muted)}.preview-controls .action-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.preview-controls .close-button{background:transparent;color:var(--text-muted);border:.0625rem solid var(--border);width:2rem;height:2rem;padding:0;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.preview-controls .close-button:hover{background:var(--color-error);border-color:var(--color-error);color:var(--color-white)}.preview-body{flex:1;display:flex;position:relative}.preview-iframe{flex:1;border:none;background:var(--color-white)}.preview-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);color:var(--text-muted)}.spinner{width:2.5rem;height:2.5rem;border:.1875rem solid var(--border);border-top:.1875rem solid var(--accent);border-radius:50%;animation:spin 1s linear infinite}.publish-modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0e0e12c7;display:flex;justify-content:center;align-items:center;z-index:1100;-webkit-backdrop-filter:blur(.375rem);backdrop-filter:blur(.375rem);padding:var(--spacing-md)}.publish-modal-content{position:relative;width:100%;max-width:30rem;background:var(--surface);border:.0625rem solid var(--border);border-radius:var(--radius-md);padding:2.25rem 1.75rem 1.75rem;text-align:left;box-shadow:0 0 0 .0625rem #7c3aed2e inset,0 1.5rem 3rem #00000080}.publish-modal-close{position:absolute;top:.875rem;right:.875rem;width:2rem;height:2rem;display:inline-flex;align-items:center;justify-content:center;background:transparent;color:var(--text-muted);border:.0625rem solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.publish-modal-close:hover{background:var(--color-error);border-color:var(--color-error);color:var(--color-white)}.publish-modal-icon{display:inline-flex;align-items:center;justify-content:center;width:3.5rem;height:3.5rem;margin-bottom:1rem;border-radius:var(--radius-md);background:var(--accent-soft);color:var(--accent)}.publish-modal-title{font-size:1.375rem;font-weight:700;color:var(--text);margin:0 0 .625rem;line-height:1.2}.publish-modal-lead{font-size:.9375rem;color:var(--text);line-height:1.5;margin:0 0 1.25rem}.publish-modal-points{list-style:none;margin:0 0 1.75rem;padding:0;display:flex;flex-direction:column;gap:.875rem}.publish-modal-points li{display:flex;gap:.75rem;align-items:flex-start;font-size:.875rem;color:var(--text-muted);line-height:1.5}.publish-modal-points li strong{color:var(--text);font-weight:600}.publish-modal-point-icon{flex:none;display:inline-flex;align-items:center;justify-content:center;width:1.875rem;height:1.875rem;border-radius:var(--radius-sm);background:var(--surface2);border:.0625rem solid var(--border);color:var(--accent)}.publish-modal-form{display:flex;flex-direction:column;gap:.875rem;margin-top:.25rem}.publish-field{display:flex;flex-direction:column;gap:.375rem}.publish-field-label{font-size:.8125rem;font-weight:600;color:var(--text)}.publish-field-optional{font-weight:400;color:var(--text-muted);margin-left:.25rem}.publish-field-input{width:100%;padding:.625rem .875rem;background:var(--surface2);border:.0625rem solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.875rem;font-family:inherit;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.publish-field-input::placeholder{color:var(--text-muted)}.publish-field-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 .1875rem var(--accent-soft)}.publish-field-input.has-error{border-color:var(--color-error)}.publish-field-input.has-error:focus{box-shadow:0 0 0 .1875rem #ef44442e}.publish-field-input:disabled{opacity:.6;cursor:not-allowed}.publish-field-error{font-size:.75rem;color:var(--color-error);line-height:1.3}.publish-modal-actions{display:flex;justify-content:flex-end;gap:.625rem;flex-wrap:wrap;margin-top:.5rem}@media (max-width: 32rem){.publish-modal-content{padding:2rem 1.25rem 1.25rem}.publish-modal-actions{flex-direction:column-reverse}.publish-modal-actions .btn{width:100%;justify-content:center}}.notification{position:fixed;bottom:var(--spacing-md);right:var(--spacing-md);padding:var(--spacing-md);background-color:var(--color-success);color:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:1001;font-size:var(--font-size-sm)}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);background:var(--bg)}.error-boundary-content{max-width:32rem;width:100%;padding:var(--spacing-2xl);background:var(--surface);border:.0625rem solid var(--border);border-radius:var(--radius-md);text-align:center;box-shadow:var(--shadow-xl)}.error-boundary-icon{display:inline-flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-md);color:var(--color-warning)}.error-boundary-content h2{color:var(--text);font-size:var(--font-size-2xl);margin-bottom:var(--spacing-sm)}.error-boundary-content p{color:var(--text-muted);margin-bottom:var(--spacing-lg)}.error-boundary-message{text-align:left;background:var(--surface2);border:.0625rem solid var(--border);border-radius:var(--radius-sm);padding:var(--spacing-md);color:var(--color-error);font-family:var(--font-mono);font-size:var(--font-size-xs);white-space:pre-wrap;word-break:break-word;margin-bottom:var(--spacing-lg);max-height:12rem;overflow:auto}.error-boundary-actions{display:flex;justify-content:center;gap:var(--spacing-sm);flex-wrap:wrap}@keyframes fadeInUp{0%{opacity:0;transform:translateY(1.25rem)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-1.25rem)}to{opacity:1;transform:translate(0)}}@keyframes bounce{0%,20%,53%,80%,to{transform:translateY(0)}40%,43%{transform:translateY(-.5rem)}70%{transform:translateY(-.25rem)}90%{transform:translateY(-.125rem)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.fade-in-up{animation:fadeInUp .6s ease-out}.slide-in-left{animation:slideInLeft .6s ease-out}.bounce{animation:bounce 2s infinite}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@media (min-width: 87.5rem){:root{--sidebar-width: clamp(20rem, 22vw, 24rem);--properties-panel-width: clamp(18rem, 20vw, 22rem)}}@media (max-width: 87.4375rem) and (min-width: 75rem){:root{--sidebar-width: clamp(16rem, 20vw, 18rem);--properties-panel-width: clamp(16rem, 18vw, 18rem)}.header-content{padding:var(--spacing-responsive-sm)}.canvas{min-width:clamp(20rem,50vw,25rem)}.main-content.with-properties .canvas{max-width:calc(100vw - var(--sidebar-width) - var(--properties-panel-width));min-width:clamp(18rem,40vw,22rem)}}@media (max-width: 74.9375rem) and (min-width: 64rem){:root{--sidebar-width: clamp(14rem, 25vw, 16rem);--properties-panel-width: clamp(14rem, 25vw, 16rem)}.canvas{min-width:clamp(18rem,40vw,22rem)}.section-wrapper:first-child{padding-top:var(--spacing-xl)}.main-content.with-properties .canvas{min-width:clamp(16rem,35vw,20rem);max-width:calc(100vw - var(--sidebar-width) - var(--properties-panel-width))}}@media (max-width: 63.9375rem) and (min-width: 56.25rem){:root{--sidebar-width: 100%;--properties-panel-width: 100%}.main-content{flex-direction:column;height:auto}.sidebar{width:100%;height:clamp(10rem,20vh,12rem);border-right:none;border-bottom:.0625rem solid var(--color-accent)}.properties-panel{width:100%;height:clamp(12rem,25vh,16rem);border-left:none;border-top:.0625rem solid var(--color-accent);order:3}.canvas{order:2;min-height:clamp(20rem,50vh,30rem)}}@media (max-width: 56.1875rem) and (min-width: 48rem){.header-content{flex-direction:column;gap:var(--spacing-responsive-sm);align-items:stretch;padding:var(--spacing-sm)}.header-left{justify-content:center}.header-actions{justify-content:center;flex-wrap:wrap;gap:var(--spacing-xs)}.main-content{flex-direction:column;height:auto}.sidebar{width:100%;height:clamp(10rem,25vh,14rem);border-right:none;border-bottom:.0625rem solid var(--color-accent)}.properties-panel{width:100%;height:clamp(12rem,30vh,18rem);border-left:none;border-top:.0625rem solid var(--color-accent)}.canvas{min-height:clamp(18rem,45vh,25rem)}}@media (max-width: 47.9375rem){:root{--spacing-responsive-sm: clamp(.25rem, 3vw, .75rem);--spacing-responsive-md: clamp(.5rem, 4vw, 1rem);--font-size-xs: clamp(.7rem, 3vw, .85rem);--font-size-sm: clamp(.8rem, 3.5vw, .95rem)}.header-content{flex-direction:column;gap:var(--spacing-responsive-sm);align-items:stretch;padding:var(--spacing-sm)}.header-left{justify-content:center}.header-actions{justify-content:center;flex-wrap:wrap;gap:var(--spacing-xs)}.main-content{flex-direction:column;height:auto}.sidebar{width:100%;height:clamp(8rem,20vh,12rem);border-right:none;border-bottom:.0625rem solid var(--color-accent)}.properties-panel{width:100%;height:clamp(10rem,25vh,16rem);border-left:none;border-top:.0625rem solid var(--color-accent)}.canvas{min-height:clamp(16rem,50vh,24rem)}.canvas-header{padding:var(--spacing-responsive-sm)}.canvas-title h2{font-size:var(--font-size-lg)}.canvas-actions{flex-wrap:wrap;gap:var(--spacing-xs)}.preview-content{width:98vw;height:98vh;margin:1vh 1vw}.preview-header{padding:var(--spacing-responsive-sm);flex-direction:column;gap:var(--spacing-responsive-sm);align-items:stretch}.preview-controls{justify-content:center;flex-wrap:wrap;gap:var(--spacing-xs)}.preview-controls .action-button.secondary{font-size:var(--font-size-xs);padding:var(--spacing-xs) var(--spacing-sm)}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){:root{--border-width: .03125rem}.header,.sidebar,.properties-panel{border-width:var(--border-width)}}@media (prefers-color-scheme: dark){:root{color-scheme:dark}}@supports (container-type: inline-size){.canvas{container-type:inline-size}@container (min-width: 30rem){.section-toolbar{flex-direction:row;justify-content:space-between}}@container (max-width: 30rem){.section-toolbar{flex-direction:column;gap:var(--spacing-xs)}}}
