*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0f1014;--bg-secondary: #1a1d24;--bg-tertiary: #252933;--bg-canvas: #16181f;--accent: #6366f1;--accent-hover: #4f46e5;--accent-light: rgba(99, 102, 241, .15);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--border: #2d3139;--border-light: #383d47;--success: #10b981;--warning: #f59e0b;--error: #ef4444;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5)}html,body{width:100%;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{width:100%;height:100%;display:flex;flex-direction:column}.editor-layout{display:flex;flex:1;overflow:hidden}.header{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:var(--bg-secondary);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm)}.header-left{display:flex;align-items:center;gap:20px}.header h1{font-size:15px;font-weight:600;color:#fff}.header-status{display:flex;align-items:center;gap:8px;font-size:12px;color:#666}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--error)}.status-dot.connected{background:var(--success)}.header-center{display:flex;align-items:center;gap:20px}.header-right{display:flex;align-items:center;gap:12px}.header-right .username{font-size:12px;color:#888}.header-user .username{font-size:13px;color:var(--text-secondary)}.btn-logout{padding:6px 12px;background:transparent;border:1px solid var(--border);border-radius:4px;color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all .15s}.btn-logout:hover{border-color:var(--error);color:var(--error)}.btn-emergency{padding:8px 16px;background:#ef44441a;border:1px solid var(--error);border-radius:6px;color:var(--error);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.btn-emergency:hover{background:var(--error);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-emergency.active{background:var(--success);border-color:var(--success);color:#fff}.btn-emergency.active:hover{background:#059669;transform:translateY(-1px)}.btn-lock{padding:8px 16px;background:#3b82f61a;border:1px solid var(--primary);border-radius:6px;color:var(--primary);font-size:15px;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.btn-lock:hover{background:#3b82f633;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-lock.locked{background:var(--warning);border-color:var(--warning);color:#000;animation:lockPulse 2s ease-in-out infinite}.btn-lock.locked:hover{background:#d97706;transform:translateY(-1px)}@keyframes lockPulse{0%,to{box-shadow:0 0 #f59e0b66}50%{box-shadow:0 0 0 8px #f59e0b00}}body.canvas-locked .canvas-element{pointer-events:none!important;cursor:default!important}body.canvas-locked .canvas-element .resize-handle{display:none!important}body.canvas-locked .canvas-element.selected{outline:none!important}body.canvas-locked .media-upload-btn,body.canvas-locked .btn-add-element,body.canvas-locked .media-upload-area,body.canvas-locked .drop-zone{display:none!important}body.canvas-locked .media-item{pointer-events:none!important;opacity:.5;cursor:not-allowed!important}.canvas-lock-indicator{position:absolute;bottom:20px;left:50%;transform:translate(-50%);font-size:15px;font-weight:400;letter-spacing:4px;color:#ffffff80;text-transform:uppercase;pointer-events:none;z-index:1;display:none}body.canvas-locked .canvas-lock-indicator{display:block}.sidebar{width:260px;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;transition:width .2s;box-shadow:var(--shadow-md)}.sidebar-section{border-bottom:1px solid #2a2a3e}.sidebar-section-header{padding:12px 16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#8b92a7;background:#16161f;border-radius:8px 8px 0 0}.sidebar-section-content{padding:12px;background:#1e1e2e;border-radius:0 0 8px 8px}.add-buttons{display:flex;gap:8px}.add-btn{flex:1;padding:12px 8px;border:1px dashed var(--border);border-radius:6px;background:transparent;color:var(--text-secondary);font-size:11px;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;align-items:center;gap:4px}.add-btn:hover{border-color:var(--accent);color:var(--accent);background:#e945601a}.add-btn svg{width:20px;height:20px}.elements-list{flex:1;overflow-y:auto}.element-item{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s}.element-item:hover{background:#ffffff08}.element-item.selected{background:#e9456026;border-left:3px solid var(--accent)}.element-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.element-info{flex:1;min-width:0}.element-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.element-type{font-size:11px;color:var(--text-muted)}.element-actions{display:flex;gap:2px;opacity:0;transition:opacity .1s}.element-item:hover .element-actions{opacity:1}.icon-btn{width:28px;height:28px;border:none;border-radius:4px;background:transparent;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center}.icon-btn:hover{background:#ffffff1a;color:var(--text-primary)}.icon-btn.danger:hover{background:#ef444433;color:var(--error)}.canvas-area{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);overflow:hidden;position:relative;cursor:default}.canvas-area:active{cursor:grabbing}.canvas-container{position:relative;background:var(--bg-canvas);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-lg)}.canvas-container:before{content:"1920 × 1080";position:absolute;top:-28px;left:50%;transform:translate(-50%);font-size:11px;color:var(--text-muted);font-weight:500}.canvas-element{position:absolute;cursor:move;-webkit-user-select:none;user-select:none;outline:2px solid transparent;border-radius:3px;transition:outline-color .15s}.canvas-element:hover{outline-color:#6366f180}.canvas-element.selected{outline-color:var(--accent);outline-width:2px;box-shadow:0 0 0 4px #6366f133}.canvas-element.selected:hover{outline-color:var(--accent-hover);box-shadow:0 0 0 4px #6366f14d}.canvas-element.dragging{opacity:.8;box-shadow:var(--shadow-lg)}.canvas-element.editing{outline-color:var(--success);cursor:text;box-shadow:0 0 0 4px #22c55e33}.canvas-element .inline-edit{background:transparent;border:none;outline:none;font-family:inherit;font-size:inherit;color:inherit;width:100%;min-width:50px}.properties-panel{width:200px;background:var(--bg-secondary);border-left:1px solid var(--border);box-shadow:var(--shadow-md);overflow-y:auto;transition:width .2s}.property-group{padding:16px 18px 12px;border-bottom:1px solid var(--border);border-radius:8px;margin-bottom:10px;background:var(--bg-tertiary);box-shadow:var(--shadow-sm)}.property-group-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:10px}.property-row{display:flex;align-items:center;margin-bottom:10px;gap:8px}.property-row:last-child{margin-bottom:0}.property-label{width:60px;font-size:12px;color:var(--text-secondary)}.property-input{flex:1;padding:7px 10px;border:1px solid var(--border);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:13px;outline:none;transition:border-color .15s,background-color .15s}.property-input:focus{border-color:var(--accent);background:var(--bg-secondary);box-shadow:0 0 0 3px #6366f11a}.property-input[type=color]{width:36px;height:32px;padding:2px;cursor:pointer}.property-input[type=range]{cursor:pointer}.property-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;border-radius:3px;background:var(--bg-tertiary);outline:none;cursor:pointer;transition:background .2s}.property-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;transition:all .2s}.property-slider::-webkit-slider-thumb:hover{background:#5a7aff;transform:scale(1.2)}.property-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;border:none;background:var(--accent);cursor:pointer;transition:all .2s}.property-slider::-moz-range-thumb:hover{background:#5a7aff;transform:scale(1.2)}.property-slider:hover{background:var(--bg-secondary)}.property-input[type=checkbox]{width:16px;height:16px;cursor:pointer}.property-row-double{display:grid;grid-template-columns:1fr 1fr;gap:6px}.property-input-group{display:flex;align-items:center;gap:6px}.property-input-group label{font-size:11px;color:var(--text-muted)}.property-input-group input{flex:1;min-width:0}.btn{padding:8px 14px;border:none;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:transparent;border:1px solid var(--border);color:var(--text-secondary)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}.empty-state{padding:30px 16px;text-align:center;color:var(--text-muted);font-size:13px}.canvas-toolbar{position:absolute;bottom:20px;right:20px;display:flex;align-items:center;gap:6px;background:#1a1d24f2;padding:8px 12px;border-radius:10px;border:1px solid var(--border-light);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-lg);z-index:100}.toolbar-btn{padding:6px 12px;border:none;border-radius:6px;background:transparent;color:var(--text-secondary);cursor:pointer;font-size:13px;font-weight:500;transition:all .2s;display:flex;align-items:center;gap:4px}.toolbar-btn:hover{background:var(--accent-light);color:var(--accent);transform:translateY(-1px)}.toolbar-divider{width:1px;height:20px;background:var(--border);margin:0 6px}.zoom-value{min-width:44px;text-align:center;font-size:11px;color:var(--text-muted)}.canvas-disconnected-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#ef444426;display:flex;align-items:center;justify-content:center;z-index:1000;pointer-events:none}.canvas-disconnected-overlay span{font-size:48px;font-weight:800;color:var(--error);text-shadow:0 2px 20px rgba(239,68,68,.5);letter-spacing:8px}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.toast-container{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:1000}.toast{padding:12px 20px;border-radius:8px;font-size:13px;font-weight:500;animation:fadeIn .2s;box-shadow:var(--shadow-lg);min-width:200px;text-align:center}.toast.success{background:var(--success);color:#fff}.toast.error{background:var(--error);color:#fff}.toast.info{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-light)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.media-library{display:flex;flex-direction:column;height:100%}.lib-tabs{display:flex;padding:8px;gap:4px;background:var(--bg-primary);border-bottom:1px solid var(--border)}.lib-tab{flex:1;display:flex;align-items:center;justify-content:center;padding:10px 8px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .2s;border-radius:6px}.lib-tab svg{width:18px;height:18px}.lib-tab:hover{color:var(--text-secondary);background:#ffffff0d}.lib-tab.active{color:var(--accent);background:var(--accent-light)}.lib-content{flex:1;overflow-y:auto;padding:12px}.lib-empty{padding:40px 20px;text-align:center;color:var(--text-muted);font-size:13px}.audio-mode-toggle{display:flex;gap:6px;margin:12px 0}.audio-mode-btn{flex:1;padding:6px 10px;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all .2s}.audio-mode-btn:hover{border-color:var(--accent);color:var(--accent)}.audio-mode-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.audio-track-list{display:flex;flex-direction:column;gap:4px}.audio-track-row{background:var(--bg-tertiary);border-radius:6px;border:1px solid transparent;overflow:hidden;transition:all .2s}.audio-track-row:hover{border-color:var(--border)}.audio-track-row.expanded{border-color:var(--accent);background:var(--accent-light)}.audio-track-header{display:flex;align-items:center;gap:8px;padding:10px 12px;cursor:pointer;transition:background .15s}.audio-track-header:hover{background:#ffffff08}.audio-track-icon{color:var(--text-muted)}.audio-track-icon svg{width:14px;height:14px}.audio-track-row.expanded .audio-track-icon{color:var(--accent)}.audio-track-name{flex:1;font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.audio-track-row.expanded .audio-track-name{color:var(--text-primary)}.audio-track-btn{width:22px;height:22px;border:none;border-radius:4px;background:transparent;color:var(--text-muted);font-size:11px;cursor:pointer;opacity:0;transition:all .15s}.audio-track-header:hover .audio-track-btn,.audio-track-row.expanded .audio-track-btn{opacity:1}.audio-track-btn:hover{background:var(--error);color:#fff}.audio-track-player{display:flex;align-items:center;gap:8px;padding:8px 12px 12px;border-top:1px solid var(--border)}.audio-track-controls{display:flex;gap:4px}.audio-ctrl-btn{width:28px;height:28px;border:1px solid var(--border);border-radius:4px;background:var(--bg-secondary);color:var(--text-secondary);font-size:11px;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.audio-ctrl-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.audio-seek-inline{flex:1;height:4px;min-width:60px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--border);border-radius:2px;cursor:pointer}.audio-seek-inline::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:10px;height:10px;border-radius:50%;background:var(--accent);cursor:pointer}.audio-seek-inline::-moz-range-thumb{width:10px;height:10px;border:none;border-radius:50%;background:var(--accent);cursor:pointer}.audio-time-inline{font-size:10px;color:var(--text-muted);min-width:32px}.audio-volume-inline{width:50px;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--border);border-radius:2px;cursor:pointer}.audio-volume-inline::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:8px;height:8px;border-radius:50%;background:var(--text-secondary);cursor:pointer}.audio-volume-inline::-moz-range-thumb{width:8px;height:8px;border:none;border-radius:50%;background:var(--text-secondary);cursor:pointer}.lib-add-btn{width:100%;padding:12px;border:1px dashed var(--border-light);border-radius:8px;background:transparent;color:var(--text-secondary);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s;margin-bottom:12px}.lib-add-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light);transform:translateY(-1px)}.lib-add-btn svg{width:16px;height:16px}.lib-section{margin-top:16px}.lib-section-title{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:8px;padding-left:4px;font-weight:600}.lib-list{display:flex;flex-direction:column;gap:4px}.lib-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;transition:all .2s;position:relative}.lib-item.clickable{cursor:pointer}.lib-item.clickable:hover{background:var(--accent-light);transform:translate(2px)}.lib-item-icon{width:32px;height:32px;border-radius:6px;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:11px;color:var(--text-secondary);flex-shrink:0}.lib-item-icon svg{width:14px;height:14px}.lib-item-name{flex:1;font-size:12px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lib-btn{width:28px;height:28px;border:none;border-radius:6px;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.lib-btn:hover{background:#ffffff1a;color:var(--text-primary)}.lib-btn.danger:hover{background:#ef444433;color:var(--error)}.lib-btn.disabled{opacity:.3;pointer-events:none}.lib-btn svg{width:14px;height:14px}.lib-dropzone{border:2px dashed #3a3a4e;border-radius:8px;padding:16px 12px;text-align:center;transition:all .2s;margin-bottom:12px}.lib-dropzone.dragover{border-color:var(--accent);background:#4f8cff1a}.lib-dropzone-label{display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;color:var(--text-muted);font-size:11px;transition:all .2s}.lib-dropzone-label svg{width:24px;height:24px;opacity:.5}.lib-dropzone-label:hover{color:var(--accent)}.lib-dropzone-label:hover svg{opacity:1}.youtube-add-section{display:flex;gap:8px;margin-bottom:12px}.youtube-url-input{flex:1;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;padding:8px 12px;color:var(--text-primary);font-size:12px;outline:none;transition:all .2s}.youtube-url-input:focus{border-color:var(--accent);background:var(--bg-secondary)}.youtube-url-input::placeholder{color:var(--text-muted)}.youtube-add-btn{display:flex;align-items:center;gap:6px;white-space:nowrap;font-size:12px}.youtube-add-btn svg{width:14px;height:14px}.lib-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.lib-grid-item{position:relative;aspect-ratio:16/9;border-radius:8px;overflow:hidden;background:var(--bg-tertiary);transition:transform .2s,box-shadow .2s;border:1px solid var(--border)}.lib-grid-item.clickable{cursor:pointer}.lib-grid-item.clickable:hover{transform:scale(1.04);box-shadow:var(--shadow-md);border-color:var(--accent)}.lib-grid-item img,.lib-grid-item video{width:100%;height:100%;object-fit:cover}.lib-grid-item video{background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%)}.lib-grid-item video:not([poster]):before{content:"▶";position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--text-secondary);pointer-events:none}.video-error-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:28px;color:var(--text-secondary);background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%);pointer-events:none}.lib-grid-delete{position:absolute;top:4px;right:4px;width:24px;height:24px;border:none;border-radius:4px;background:#000000b3;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .15s}.lib-grid-item:hover .lib-grid-delete{opacity:1}.lib-grid-delete:hover{background:var(--error)}.lib-grid-delete svg{width:14px;height:14px}.lib-layers{display:flex;flex-direction:column;gap:4px}.lib-layer{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:all .2s;border:1px solid transparent}.lib-layer:hover{background:#ffffff0d}.lib-layer.selected{background:var(--accent-light);border-color:var(--accent)}.lib-layer.hidden{opacity:.4}.lib-layer-preview{width:40px;height:40px;border-radius:6px;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;border:1px solid var(--border)}.lib-layer-preview svg{width:16px;height:16px;opacity:.5}.lib-layer-preview .layer-thumb{width:100%;height:100%;object-fit:cover}.youtube-thumb{position:relative}.youtube-thumb:after{content:"YT";position:absolute;bottom:2px;right:2px;background:red;color:#fff;font-size:8px;font-weight:700;padding:1px 3px;border-radius:2px;pointer-events:none}.lib-layer-preview .layer-text-preview{font-weight:600;font-size:12px}.lib-layer-info{flex:1;min-width:0}.lib-layer-name{font-size:13px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;font-weight:500}.lib-layer-type{font-size:10px;color:var(--text-muted);text-transform:capitalize}.lib-layer-name{font-size:10px;color:#555;text-transform:capitalize}.lib-layer-actions{display:flex;gap:2px}.upload-progress{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#4f8cff1a;border-radius:6px;margin-bottom:10px;font-size:11px;color:var(--accent)}.upload-spinner{width:14px;height:14px;border:2px solid rgba(79,140,255,.3);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.canvas-element{position:absolute;cursor:move;-webkit-user-select:none;user-select:none}.canvas-element .element-content{width:100%;height:100%;pointer-events:none;overflow:hidden}.canvas-element .element-content img{width:100%;height:100%;object-fit:fill;display:block}.canvas-element.selected{outline:2px solid var(--accent);outline-offset:2px}.canvas-element.dragging{cursor:grabbing;opacity:.9}.canvas-element.editing{cursor:text}.canvas-element.resizing{opacity:.9}.canvas-element.element-hidden{opacity:.35!important;outline:2px dashed rgba(99,102,241,.4)!important}.canvas-element.element-hidden:before{content:"СКРЫТ";position:absolute;top:-24px;left:50%;transform:translate(-50%);background:var(--bg-tertiary);color:var(--accent);padding:2px 8px;font-size:9px;border-radius:4px;border:1px solid var(--accent);white-space:nowrap;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.reset-size-btn{position:absolute;top:-32px;left:50%;transform:translate(-50%);width:26px;height:26px;border:1px solid var(--border);border-radius:6px;background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s;z-index:20;pointer-events:auto}.canvas-element.selected .reset-size-btn{opacity:1}.reset-size-btn:hover{background:var(--accent);color:#fff;transform:translate(-50%) translateY(-2px);box-shadow:var(--shadow-md)}.hide-element-btn{position:absolute;top:-32px;right:-5px;width:26px;height:26px;border:1px solid var(--border);border-radius:6px;background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s;z-index:20;pointer-events:auto}.canvas-element.selected .hide-element-btn{opacity:1}.hide-element-btn:hover{background:var(--accent);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md)}.reset-size-btn svg{width:14px;height:14px}.resize-handle{position:absolute;width:10px;height:10px;background:#fff;border:2px solid var(--accent);border-radius:3px;opacity:0;transition:opacity .2s,background-color .2s;z-index:10}.canvas-element.selected .resize-handle{opacity:1}.resize-handle:hover{background:var(--accent);box-shadow:0 0 0 2px #6366f14d}.resize-nw{top:-5px;left:-5px;cursor:nw-resize}.resize-ne{top:-5px;right:-5px;cursor:ne-resize}.resize-sw{bottom:-5px;left:-5px;cursor:sw-resize}.resize-se{bottom:-5px;right:-5px;cursor:se-resize}.resize-n{top:-5px;left:50%;transform:translate(-50%);cursor:n-resize}.resize-s{bottom:-5px;left:50%;transform:translate(-50%);cursor:s-resize}.resize-w{top:50%;left:-5px;transform:translateY(-50%);cursor:w-resize}.resize-e{top:50%;right:-5px;transform:translateY(-50%);cursor:e-resize}.snap-guide{position:absolute;pointer-events:none;z-index:1000}.snap-guide.vertical{width:1px;top:0;bottom:0;left:0;background:#ef444499}.snap-guide.vertical.edge{background:#6366f180}.snap-guide.vertical.center{left:50%;width:2px;background:linear-gradient(to bottom,transparent 0%,#ef4444 10%,#ef4444 90%,transparent 100%);box-shadow:0 0 8px #ef444499}.snap-guide.horizontal{height:1px;left:0;right:0;top:0;background:#ef444499}.snap-guide.horizontal.edge{background:#6366f180}.snap-guide.horizontal.center{top:50%;height:2px;background:linear-gradient(to right,transparent 0%,#ef4444 10%,#ef4444 90%,transparent 100%);box-shadow:0 0 8px #ef444499}.inline-edit{background:transparent;border:none;outline:none;min-width:20px}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}.login-card{width:100%;max-width:380px;padding:40px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;box-shadow:0 20px 60px #0006}.login-card h1{font-size:24px;font-weight:600;text-align:center;margin-bottom:8px}.login-card .subtitle{text-align:center;color:var(--text-secondary);font-size:14px;margin-bottom:32px}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:13px;font-weight:500;color:var(--text-secondary)}.form-group input{padding:12px 14px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:14px;transition:border-color .15s,box-shadow .15s}.form-group input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #6366f126}.form-group input::placeholder{color:var(--text-muted)}.login-btn{padding:14px;background:var(--accent);border:none;border-radius:6px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:8px}.login-btn:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.login-btn:active{transform:scale(.98)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-error{padding:12px;background:#ef444426;border:1px solid var(--error);border-radius:6px;color:var(--error);font-size:13px;text-align:center}.otp-form{display:flex;flex-direction:column;gap:20px}.otp-info{text-align:center;color:var(--text-secondary);font-size:14px;line-height:1.5}.otp-info .highlight{color:var(--accent);font-weight:500}.otp-input-wrapper{display:flex;justify-content:center}.otp-input-wrapper input{width:160px;padding:16px;background:var(--bg-tertiary);border:2px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:24px;font-weight:600;text-align:center;letter-spacing:8px;transition:border-color .15s}.otp-input-wrapper input:focus{outline:none;border-color:var(--accent)}.otp-timer{text-align:center;color:var(--text-muted);font-size:12px}.otp-timer span{color:var(--warning);font-weight:500}.otp-actions{display:flex;gap:12px}.otp-actions .btn-secondary{flex:1;padding:12px;background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .15s}.otp-actions .btn-secondary:hover{border-color:var(--text-secondary);color:var(--text-primary)}.otp-actions .btn-primary{flex:2;padding:12px;background:var(--accent);border:none;border-radius:6px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.otp-actions .btn-primary:hover{background:var(--accent-hover)}.otp-actions .btn-primary:disabled{opacity:.7;cursor:not-allowed}.upload-progress{display:flex;align-items:center;gap:10px;padding:12px;background:var(--bg-tertiary);border-radius:6px;margin-bottom:12px;color:var(--text-secondary);font-size:13px}.upload-progress-spinner{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.media-loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--text-muted);font-size:13px}.media-loading:before{content:"";width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin-right:10px}.uptime-block{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.uptime-label{display:flex;align-items:center;gap:6px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.uptime-dot{width:6px;height:6px;border-radius:50%;background:var(--error)}.uptime-value{font-size:14px;font-weight:700;font-family:monospace;color:var(--text-primary)}.header-divider{width:1px;height:24px;background:var(--border)}.btn-icon{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.btn-icon:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--accent);transform:translateY(-1px)}.modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;width:90%;max-width:500px;box-shadow:var(--shadow-lg);animation:modalFadeIn .2s}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-header h2{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.modal-close{width:32px;height:32px;padding:0;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:6px;color:var(--text-secondary);font-size:24px;cursor:pointer;transition:all .2s}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-body{padding:24px}.modal-body .form-group{margin-bottom:20px}.modal-body .form-group:last-child{margin-bottom:0}.modal-body .form-group label{display:block;font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.modal-body .form-group small{display:block;font-size:11px;color:var(--text-muted);margin-top:6px}.url-copy-group{display:flex;gap:8px}.url-copy-group .property-input{flex:1}.btn-copy{width:40px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.btn-copy:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}.video-controls{position:absolute;bottom:0;left:0;right:0;display:flex;align-items:center;gap:10px;padding:10px 14px;background:linear-gradient(transparent,#000c);opacity:0;transition:opacity .2s;z-index:10;pointer-events:none}.canvas-element:hover .video-controls{opacity:1;pointer-events:auto}.video-ctrl-btn{width:28px;height:28px;padding:0;display:flex;align-items:center;justify-content:center;background:#fff3;border:none;border-radius:4px;color:#fff;font-size:12px;cursor:pointer;transition:background .2s}.video-ctrl-btn.play-pause{width:44px;height:44px;font-size:20px;border-radius:50%;background:#3b82f6cc;box-shadow:0 2px 8px #0000004d}.video-ctrl-btn.play-pause:hover{background:#3b82f6;transform:scale(1.1)}.video-ctrl-btn:hover{background:#ffffff59}.video-seek{flex:1;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ffffff4d;border-radius:2px;cursor:pointer}.video-seek::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;background:#fff;border-radius:50%;cursor:pointer}.video-seek::-moz-range-thumb{width:12px;height:12px;background:#fff;border:none;border-radius:50%;cursor:pointer}.video-time{font-size:10px;color:#ffffffe6;white-space:nowrap;min-width:70px;text-align:right}.video-mute-btn{position:absolute;top:8px;right:8px;width:32px;height:32px;border:none;border-radius:6px;background:#000000b3;color:#fff;font-size:16px;cursor:pointer;transition:all .2s;z-index:11;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none}.canvas-element:hover .video-mute-btn{opacity:1;pointer-events:auto}.video-mute-btn:hover{background:#000000e6;transform:scale(1.1)}
