.template-editor{display:flex;flex-direction:column;position:fixed;top:56px;left:0;right:0;bottom:0;overflow:hidden}.te-topbar{display:flex;align-items:center;gap:1rem;padding:.75rem 1.25rem;background:var(--bg-card);border-bottom:1px solid var(--border);flex-shrink:0;z-index:10}.te-back-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);font-size:1.1rem;flex-shrink:0}.te-back-btn:hover{color:var(--text-primary);border-color:#3d4160;background:var(--bg-elevated)}.te-name-input{background:transparent;border:1px solid transparent;color:var(--text-primary);font-size:1.1rem;font-weight:600;padding:.3rem .6rem;border-radius:var(--radius-sm);outline:none;transition:all var(--transition);min-width:200px;max-width:400px;font-family:inherit}.te-name-input:hover{border-color:var(--border)}.te-name-input:focus{border-color:var(--border-focus);background:var(--bg-primary);box-shadow:0 0 0 3px var(--accent-muted)}.te-topbar-right{margin-left:auto;display:flex;align-items:center;gap:.75rem}.te-undo-btn,.te-redo-btn{font-size:1.1rem;padding:.2rem .5rem;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);color:#ccc;border-radius:4px;cursor:pointer;line-height:1}.te-undo-btn:hover:not(:disabled),.te-redo-btn:hover:not(:disabled){background:#ffffff1f;color:#fff}.te-undo-btn:disabled,.te-redo-btn:disabled{opacity:.3;cursor:default}.te-save-btn{position:relative}.te-save-btn .dirty-dot{position:absolute;top:-3px;right:-3px;width:8px;height:8px;border-radius:50%;background:var(--warning);box-shadow:0 0 6px #f59e0b80}.te-saved-msg{font-size:.8rem;color:var(--success);font-weight:500;animation:te-fade-in-out 2s ease forwards}@keyframes te-fade-in-out{0%{opacity:0;transform:translateY(2px)}15%{opacity:1;transform:translateY(0)}70%{opacity:1}to{opacity:0}}.te-body{display:flex;flex:1;overflow:hidden}.te-canvas-column{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.te-preview-bar{display:flex;gap:6px;padding:6px 12px;align-items:center;flex-shrink:0;background:var(--bg-card);border-bottom:1px solid var(--border)}.te-preview-slot-wrap,.te-preview-thumb-wrap{position:relative}.te-preview-thumb-wrap:hover .te-preview-remove,.te-preview-thumb-wrap:hover .te-preview-replace{opacity:1}.te-preview-remove,.te-preview-replace{position:absolute;width:18px;height:18px;border-radius:50%;border:none;background:#000000b3;color:#fff;font-size:.55rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;padding:0;line-height:1}.te-preview-remove{top:-4px;right:-4px}.te-preview-remove:hover{background:#dc3232e6}.te-preview-replace{bottom:-4px;right:-4px;font-size:.7rem}.te-preview-replace:hover{background:#5078c8e6}.te-preview-thumb{width:96px;height:56px;border-radius:4px;border:2px solid transparent;cursor:pointer;overflow:hidden;padding:0;background:transparent;transition:border-color .15s}.te-preview-thumb:hover{border-color:#ffffff4d}.te-preview-thumb.active{border-color:var(--accent)}.te-preview-thumb img{width:100%;height:100%;object-fit:cover;display:block}.te-preview-checkerboard{width:100%;height:100%;background:repeating-conic-gradient(#2a2d37,#2a2d37 25%,#1f2129 0%,#1f2129 50%) 0 0 / 8px 8px;border-radius:2px}.te-preview-empty{display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:1rem;background:#ffffff08;border:2px dashed rgba(255,255,255,.12)}.te-preview-empty:hover{border-color:#ffffff40;color:var(--text-secondary)}.te-canvas-area{flex:1;display:flex;align-items:center;justify-content:center;padding:1.5rem;overflow:hidden;position:relative;min-width:0}.te-canvas-wrapper{position:relative;background:repeating-conic-gradient(#1a1d27,#1a1d27 25%,#15171f 0%,#15171f 50%) 0 0 / 20px 20px;border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;box-shadow:var(--shadow-lg)}.te-canvas{position:relative;width:1920px;height:1080px;transform-origin:top left}.te-guide-h,.te-guide-v{position:absolute;pointer-events:none;z-index:5}.te-guide-h{left:0;right:0;height:0;border-top:1px dashed rgba(99,102,241,.45)}.te-guide-v{top:0;bottom:0;width:0;border-left:1px dashed rgba(99,102,241,.45)}.te-overlay-element{position:absolute;cursor:move;-webkit-user-select:none;user-select:none}.te-overlay-element.selected{outline:2px solid var(--accent);outline-offset:1px}.te-overlay-element.dragging{outline-color:var(--accent-hover)}.te-clip-mask{position:absolute;top:0;right:0;bottom:0;left:0;box-shadow:0 0 0 9999px #0000008c;pointer-events:none;z-index:50}.te-selection-label{position:absolute;top:-20px;left:0;background:var(--accent);color:#fff;font-size:.6rem;font-weight:600;padding:1px 6px;border-radius:3px 3px 0 0;white-space:nowrap;pointer-events:none;z-index:100;line-height:1.5}.te-resize-handle{position:absolute;width:8px;height:8px;background:var(--accent);border:1px solid #fff;border-radius:1px;z-index:10}.te-resize-handle.nw{top:-4px;left:-4px;cursor:nw-resize}.te-resize-handle.n{top:-4px;left:50%;margin-left:-4px;cursor:n-resize}.te-resize-handle.ne{top:-4px;right:-4px;cursor:ne-resize}.te-resize-handle.e{top:50%;margin-top:-4px;right:-4px;cursor:e-resize}.te-resize-handle.se{bottom:-4px;right:-4px;cursor:se-resize}.te-resize-handle.s{bottom:-4px;left:50%;margin-left:-4px;cursor:s-resize}.te-resize-handle.sw{bottom:-4px;left:-4px;cursor:sw-resize}.te-resize-handle.w{top:50%;margin-top:-4px;left:-4px;cursor:w-resize}.te-drag-tooltip{position:absolute;background:#0f0f19eb;color:var(--text-primary);font-size:11px;font-family:Cascadia Code,Fira Code,Consolas,monospace;padding:4px 8px;border-radius:4px;pointer-events:none;white-space:nowrap;z-index:20;border:1px solid var(--border);box-shadow:var(--shadow)}.te-left-panel{width:260px;min-width:260px;background:var(--bg-card);border-right:1px solid var(--border);overflow:hidden;flex-shrink:0;display:flex;flex-direction:column}.te-left-tree{flex:3 1 0;overflow-y:auto;min-height:0;display:flex;flex-direction:column;background:var(--bg-card)}.te-left-tree>.te-section{flex:1 1 0;display:flex;flex-direction:column;border-bottom:none}.te-left-tree>.te-section>.te-section-body{flex:1 1 0;display:flex;flex-direction:column}.te-left-tree .te-el-list,.te-left-tree .te-el-empty{flex:1 1 0;background:#ffffff08;border-radius:6px;padding:.35rem;margin-top:.4rem}.te-left-schema>.te-section{height:100%;display:flex;flex-direction:column}.te-left-schema>.te-section>.te-section-body{flex:1 1 0}.te-left-schema{flex:2 1 0;overflow-y:auto;min-height:0;border-top:1px solid var(--border)}.te-right-panel{width:340px;min-width:340px;background:var(--bg-card);border-left:1px solid var(--border);flex-shrink:0;display:flex;flex-direction:column;overflow:hidden}.te-tab-bar{display:flex;border-bottom:1px solid var(--border);flex-shrink:0}.te-tab-btn{flex:1;padding:.6rem .4rem;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.te-tab-btn:hover{color:var(--text-primary);background:#ffffff08}.te-tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.te-tab-content{flex:1;overflow-y:auto;padding:.75rem .5rem}.te-sidebar{width:340px;min-width:340px;background:var(--bg-card);border-left:1px solid var(--border);overflow-y:auto;flex-shrink:0}.te-section{border-bottom:1px solid var(--border)}.te-section-header{display:flex;align-items:center;justify-content:space-between;padding:.6rem .75rem;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition)}.te-section-header:hover{background:var(--bg-elevated)}.te-section-title{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary)}.te-section-chevron{font-size:.7rem;color:var(--text-muted);transition:transform var(--transition)}.te-section-chevron.open{transform:rotate(180deg)}.te-section-body{padding:0 .75rem .75rem}.te-prop-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.6rem}.te-prop-label{font-size:.78rem;color:var(--text-secondary);min-width:50px;flex-shrink:0;font-weight:500}.te-prop-input{flex:1;min-width:0;padding:.4rem .6rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.82rem;font-family:inherit;outline:none;transition:border-color var(--transition)}.te-prop-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 2px var(--accent-muted)}.te-prop-input[type=number]{font-family:Cascadia Code,Fira Code,Consolas,monospace;font-size:.8rem}.te-mode-toggle{display:flex;gap:2px;background:#00000040;border:1px solid var(--border);border-radius:6px;padding:2px}.te-mode-toggle button{flex:1;padding:.25rem .5rem;background:none;border:none;border-radius:4px;color:var(--text-muted);font-size:.72rem;font-weight:500;cursor:pointer;font-family:inherit;transition:background .15s,color .15s}.te-mode-toggle button:hover{color:var(--text);background:#ffffff0f}.te-mode-toggle button.active{background:var(--accent);color:#fff}.te-anchor-input-label{font-size:.7rem;color:var(--text-muted);font-weight:500}.te-anchor-input{width:100%;box-sizing:border-box;margin:0;padding:.3rem .4rem;font-size:.78rem}.te-anchor-grid{display:grid;grid-template-columns:repeat(3,40px);grid-template-rows:repeat(3,30px);gap:2px;padding:4px;background:#ffffff08;border:1px solid var(--border);border-radius:6px;flex-shrink:0}.te-anchor-cell{position:relative;background:#ffffff08;border:1px solid rgba(255,255,255,.07);border-radius:3px;cursor:pointer;padding:0;transition:background .1s,border-color .1s;overflow:hidden}.te-anchor-cell:hover{background:#6366f11f;border-color:#6366f166}.te-anchor-cell.active{background:#6366f133;border-color:var(--accent)}.te-anchor-dot{position:absolute;width:8px;height:6px;border-radius:1px;background:#ffffff40;transition:background .1s}.te-anchor-cell:hover .te-anchor-dot{background:#6366f1cc}.te-anchor-cell.active .te-anchor-dot{background:var(--accent)}.te-presets{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.5rem}.te-preset-btn{padding:.3rem .6rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.72rem;cursor:pointer;transition:all var(--transition);font-family:inherit;white-space:nowrap}.te-preset-btn:hover{color:var(--text-primary);border-color:var(--accent);background:var(--accent-muted)}.te-slider-row{display:flex;align-items:center;gap:.6rem;margin-bottom:.6rem}.te-slider{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;background:var(--border);border-radius:2px;outline:none}.te-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid #fff;box-shadow:0 1px 4px #0000004d;transition:box-shadow var(--transition)}.te-slider::-webkit-slider-thumb:hover{box-shadow:0 0 0 4px var(--accent-muted),0 1px 4px #0000004d}.te-slider-value{font-size:.78rem;font-family:Cascadia Code,Fira Code,Consolas,monospace;color:var(--text-secondary);min-width:48px;text-align:right}.te-color-row{display:flex;align-items:center;gap:.6rem;margin-bottom:.6rem}.te-color-swatch{width:32px;height:32px;border-radius:var(--radius-sm);border:2px solid var(--border);cursor:pointer;flex-shrink:0;position:relative;overflow:hidden}.te-color-swatch input[type=color]{position:absolute;top:-4px;left:-4px;width:calc(100% + 8px);height:calc(100% + 8px);border:none;cursor:pointer;opacity:0}.te-select{flex:1;min-width:0;padding:.4rem 2rem .4rem .6rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.82rem;font-family:inherit;outline:none;transition:border-color var(--transition);-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2394a3b8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .6rem center}.te-select:focus{border-color:var(--border-focus);box-shadow:0 0 0 2px var(--accent-muted)}.te-preview-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .7rem;background:var(--accent-muted);border:1px solid rgba(99,102,241,.3);border-radius:var(--radius-sm);color:var(--accent-hover);font-size:.75rem;cursor:pointer;transition:all var(--transition);font-family:inherit;font-weight:500}.te-preview-btn:hover{background:#6366f140;border-color:var(--accent)}.te-field-item{display:flex;align-items:center;gap:.5rem;padding:.6rem 0;border-bottom:1px solid var(--border)}.te-field-item:last-child{border-bottom:none}.te-field-name{font-size:.82rem;font-weight:600;color:var(--accent-hover);font-family:Cascadia Code,Fira Code,Consolas,monospace;min-width:0;flex-shrink:0}.te-field-type{font-size:.68rem;padding:.1rem .4rem;background:var(--accent-muted);color:var(--accent-hover);border-radius:100px;text-transform:uppercase;font-weight:600;letter-spacing:.03em;flex-shrink:0}.te-field-default{flex:1;min-width:0}.te-field-delete{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all var(--transition);font-size:.85rem;flex-shrink:0}.te-field-delete:hover{color:var(--danger);border-color:#ef44444d;background:#ef44441a}.te-add-field-form{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.6rem;padding-top:.6rem;border-top:1px solid var(--border)}.te-preview-overlay{width:100%;height:100%;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;overflow:hidden}.te-preview-scoreboard{display:flex;align-items:center;background:#0f0f19e6;border-radius:12px;overflow:hidden;box-shadow:0 8px 32px #00000080;height:100%}.te-preview-scoreboard .team{display:flex;align-items:center;padding:12px 24px;gap:16px;flex:1}.te-preview-scoreboard .team-a{justify-content:flex-end}.te-preview-scoreboard .team-b{justify-content:flex-start}.te-preview-scoreboard .team-name{font-size:18px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:1px}.te-preview-scoreboard .team-score{font-size:32px;font-weight:900;color:#fff;min-width:50px;text-align:center;padding:4px 12px;border-radius:6px}.te-preview-scoreboard .divider{color:#fff6;font-size:14px;font-weight:700;padding:0 12px;text-transform:uppercase;letter-spacing:2px;flex-shrink:0}.te-preview-lower-third{display:flex;overflow:hidden;border-radius:8px;box-shadow:0 8px 32px #00000080;height:100%}.te-preview-lower-third .accent-bar{width:6px;background:#3b82f6;flex-shrink:0}.te-preview-lower-third .content{background:#0f0f19eb;padding:14px 28px;flex:1;display:flex;flex-direction:column;justify-content:center}.te-preview-lower-third .title{font-size:22px;font-weight:700;color:#fff;line-height:1.3}.te-preview-lower-third .subtitle{font-size:14px;color:#fff9;font-weight:400;margin-top:2px}.te-preview-timer{background:#0f0f19e6;border-radius:10px;padding:10px 28px;text-align:center;box-shadow:0 8px 32px #00000080;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center}.te-preview-timer .label{font-size:11px;color:#ffffff80;text-transform:uppercase;letter-spacing:2px;font-weight:600}.te-preview-timer .time{font-size:36px;font-weight:900;color:#fff;font-variant-numeric:tabular-nums;letter-spacing:2px}.te-preview-custom{background:#0f0f19e6;border-radius:12px;padding:20px 30px;box-shadow:0 8px 32px #00000080;height:100%;overflow:auto}.te-preview-custom .field{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.08)}.te-preview-custom .field:last-child{border-bottom:none}.te-preview-custom .field-key{font-size:12px;color:#ffffff80;text-transform:uppercase;letter-spacing:1px;font-weight:600}.te-preview-custom .field-value{font-size:16px;color:#fff;font-weight:700}@keyframes te-anim-fade-in{0%{opacity:0}to{opacity:1}}@keyframes te-anim-slide-down-in{0%{transform:translateY(-40px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes te-anim-slide-up-in{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes te-anim-slide-left-in{0%{transform:translate(40px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes te-anim-slide-right-in{0%{transform:translate(-40px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes te-anim-scale-up-in{0%{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}@keyframes te-anim-bounce-in{0%{transform:scale(.3);opacity:0}50%{transform:scale(1.08)}70%{transform:scale(.95)}to{transform:scale(1);opacity:1}}@keyframes te-anim-pulse-in{0%{opacity:0;transform:scale(.8)}50%{opacity:1;transform:scale(1.1)}to{transform:scale(1)}}@keyframes te-anim-flash-in{0%{opacity:0;filter:brightness(3)}to{opacity:1;filter:brightness(1)}}@keyframes te-anim-flip-in{0%{opacity:0;transform:scaleY(0)}60%{opacity:1;transform:scaleY(1.05)}to{transform:scaleY(1)}}@keyframes te-anim-shake-in{0%{opacity:0;transform:translate(-8px)}20%{opacity:1;transform:translate(8px)}40%{transform:translate(-5px)}60%{transform:translate(5px)}80%{transform:translate(-2px)}to{transform:translate(0)}}@keyframes te-anim-color-pop-in{0%{opacity:0;filter:brightness(2) saturate(2)}to{opacity:1;filter:brightness(1) saturate(1)}}@keyframes te-anim-wipe-right-in{0%{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 0 0 0)}}@keyframes te-anim-wipe-left-in{0%{clip-path:inset(0 0 0 100%)}to{clip-path:inset(0 0 0 0)}}@keyframes te-anim-wipe-down-in{0%{clip-path:inset(0 0 100% 0)}to{clip-path:inset(0 0 0 0)}}@keyframes te-anim-wipe-up-in{0%{clip-path:inset(100% 0 0 0)}to{clip-path:inset(0 0 0 0)}}@keyframes te-anim-fade-out{0%{opacity:1}to{opacity:0}}@keyframes te-anim-slide-down-out{0%{transform:translateY(0);opacity:1}to{transform:translateY(40px);opacity:0}}@keyframes te-anim-slide-up-out{0%{transform:translateY(0);opacity:1}to{transform:translateY(-40px);opacity:0}}@keyframes te-anim-slide-left-out{0%{transform:translate(0);opacity:1}to{transform:translate(-40px);opacity:0}}@keyframes te-anim-slide-right-out{0%{transform:translate(0);opacity:1}to{transform:translate(40px);opacity:0}}@keyframes te-anim-scale-down-out{0%{transform:scale(1);opacity:1}to{transform:scale(.7);opacity:0}}@keyframes te-anim-bounce-out{0%{transform:scale(1);opacity:1}40%{transform:scale(1.08)}to{transform:scale(.3);opacity:0}}@keyframes te-anim-pulse-out{0%{transform:scale(1);opacity:1}50%{transform:scale(1.1)}to{transform:scale(.8);opacity:0}}@keyframes te-anim-flash-out{0%{opacity:1;filter:brightness(1)}50%{filter:brightness(3)}to{opacity:0;filter:brightness(1)}}@keyframes te-anim-flip-out{0%{transform:scaleY(1);opacity:1}to{transform:scaleY(0);opacity:0}}@keyframes te-anim-shake-out{0%{transform:translate(0);opacity:1}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-5px);opacity:.5}80%{transform:translate(2px);opacity:.2}to{transform:translate(0);opacity:0}}@keyframes te-anim-color-pop-out{0%{opacity:1;filter:brightness(1) saturate(1)}50%{filter:brightness(1.5) saturate(2)}to{opacity:0;filter:brightness(1) saturate(1)}}@keyframes te-anim-wipe-right-out{0%{clip-path:inset(0 0 0 0)}to{clip-path:inset(0 0 0 100%)}}@keyframes te-anim-wipe-left-out{0%{clip-path:inset(0 0 0 0)}to{clip-path:inset(0 100% 0 0)}}@keyframes te-anim-wipe-down-out{0%{clip-path:inset(0 0 0 0)}to{clip-path:inset(100% 0 0 0)}}@keyframes te-anim-wipe-up-out{0%{clip-path:inset(0 0 0 0)}to{clip-path:inset(0 0 100% 0)}}.te-loading{display:flex;align-items:center;justify-content:center;height:calc(100vh - 56px);color:var(--text-muted);font-size:1rem}.te-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:calc(100vh - 56px);color:var(--text-muted);gap:1rem}.te-confirm-delete{display:flex;align-items:center;gap:.4rem;font-size:.75rem}.te-confirm-delete span{color:var(--danger);font-weight:500}.te-el-layer{transition:box-shadow .15s ease;pointer-events:auto}.te-el-layer:hover{box-shadow:inset 0 0 0 1px #6366f180}.te-el-selected{box-shadow:inset 0 0 0 2px #6366f1e6!important}.te-el-add-row{display:flex;gap:.5rem;margin-bottom:.5rem}.te-el-empty{color:var(--text-muted);font-size:.8rem;padding:.5rem 0;line-height:1.4}.te-el-list{display:flex;flex-direction:column;gap:2px}.te-el-item{display:flex;align-items:center;gap:.2rem;padding:.25rem .3rem;border-radius:4px;cursor:pointer;font-size:.8rem;background:transparent;transition:background .15s}.te-el-item:hover{background:#ffffff0d}.te-el-item.active{background:#6366f133;outline:1px solid rgba(99,102,241,.5)}.te-el-collapse-btn{width:12px;height:12px;display:flex;align-items:center;justify-content:center;font-size:.45rem;flex-shrink:0;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:0;border-radius:2px;line-height:1}.te-el-collapse-btn:hover{background:#ffffff14;color:var(--text)}.te-el-collapse-spacer{pointer-events:none}.te-el-item-icon{width:14px;height:14px;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:800;color:var(--accent);background:#6366f126;border-radius:4px;flex-shrink:0}.te-el-item-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}.te-el-item-actions{display:flex;gap:2px;opacity:0;transition:opacity .15s}.te-el-item:hover .te-el-item-actions{opacity:1}.te-el-item-actions button{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px 4px;font-size:.65rem;border-radius:3px;line-height:1}.te-el-item-actions button:hover{background:#ffffff1a;color:var(--text)}.te-el-item[draggable]{cursor:grab;position:relative}.te-el-item.dragging{opacity:.3}.te-el-item.drop-before{box-shadow:0 -2px 0 0 var(--accent, #5b9aff)}.te-el-item.drop-after{box-shadow:0 2px 0 0 var(--accent, #5b9aff)}.te-el-item.drop-inside{background:#64b4ff26;outline:1px dashed rgba(100,180,255,.5);outline-offset:-1px}.te-ctx-menu{position:fixed;z-index:1000;background:var(--bg-card, #1e1e2e);border:1px solid var(--border, #333);border-radius:8px;padding:4px 0;min-width:160px;box-shadow:0 8px 24px #00000080}.te-ctx-label{font-size:.65rem;color:var(--text-muted);padding:4px 12px 2px;text-transform:uppercase;letter-spacing:.04em}.te-ctx-item{display:block;width:100%;text-align:left;padding:6px 12px;font-size:.78rem;color:var(--text, #cdd6f4);background:none;border:none;cursor:pointer}.te-ctx-item:hover{background:#ffffff14}.te-ctx-danger{color:#f38ba8}.te-ctx-danger:hover{background:#f38ba81f}.te-ctx-sep{height:1px;background:var(--border, #333);margin:4px 8px}.te-el-textarea{width:100%;background:var(--surface-2);border:1px solid var(--border);border-radius:6px;color:var(--text);padding:.4rem .6rem;font-family:Cascadia Code,Fira Code,monospace;font-size:.8rem;resize:vertical;line-height:1.4}.te-el-textarea:focus{outline:none;border-color:var(--accent)}.te-binding-hints{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px;font-size:.72rem;color:var(--text-muted);align-items:center}.te-binding-chip{background:#6366f126;border:1px solid rgba(99,102,241,.3);color:var(--accent-hover);border-radius:4px;padding:1px 6px;font-size:.7rem;font-family:Cascadia Code,monospace;cursor:pointer;transition:background .15s}.te-binding-chip:hover{background:#6366f14d}.te-prop-group{margin-bottom:.5rem}.te-prop-label-full{display:block;font-size:.75rem;color:var(--text-muted);margin-bottom:4px;font-weight:500}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #0f1117;--bg-card: #1a1d27;--bg-elevated: #222639;--accent: #6366f1;--accent-hover: #818cf8;--accent-muted: rgba(99, 102, 241, .15);--text-primary: #e2e8f0;--text-secondary: #94a3b8;--text-muted: #64748b;--border: #2d3148;--border-focus: #6366f1;--danger: #ef4444;--danger-hover: #f87171;--success: #22c55e;--success-muted: rgba(34, 197, 94, .15);--warning: #f59e0b;--radius: 8px;--radius-sm: 6px;--shadow: 0 2px 8px rgba(0, 0, 0, .3);--shadow-lg: 0 4px 24px rgba(0, 0, 0, .4);--transition: .15s ease}html{font-size:14px}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:2rem;max-width:1400px;width:100%;margin:0 auto}.nav-header{background:var(--bg-card);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.nav-inner{max-width:1400px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;height:56px;gap:2rem}.nav-brand{font-size:1.25rem;font-weight:700;color:var(--text-primary);text-decoration:none;display:flex;align-items:center;gap:.5rem;letter-spacing:-.02em}.brand-icon{color:var(--accent);font-size:1.1rem}.nav-links{display:flex;gap:.25rem}.nav-link{color:var(--text-secondary);text-decoration:none;padding:.5rem 1rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;transition:all var(--transition)}.nav-link:hover{color:var(--text-primary);background:var(--accent-muted)}.nav-link.active{color:var(--accent);background:var(--accent-muted)}.page-header{margin-bottom:2rem}.page-header h1{font-size:1.75rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.25rem}.page-header p{color:var(--text-secondary);font-size:.95rem}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;transition:all var(--transition)}.card:hover{border-color:#3d4160}.card-clickable{cursor:pointer}.card-clickable:hover{border-color:var(--accent);box-shadow:var(--shadow);transform:translateY(-1px)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.55rem 1.1rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;border:none;cursor:pointer;transition:all var(--transition);text-decoration:none;line-height:1.4;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 0 16px #6366f14d}.btn-secondary{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){color:var(--text-primary);border-color:#3d4160;background:var(--bg-elevated)}.btn-danger{background:transparent;color:var(--danger);border:1px solid rgba(239,68,68,.3)}.btn-danger:hover:not(:disabled){background:#ef44441a;border-color:var(--danger)}.btn-success{background:var(--success);color:#000;font-weight:600}.btn-success:hover:not(:disabled){background:#4ade80;box-shadow:0 0 16px #22c55e4d}.btn-sm{padding:.35rem .75rem;font-size:.8rem}.btn-icon{padding:.4rem .6rem}.input,.textarea,.select{width:100%;padding:.55rem .85rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.875rem;font-family:inherit;transition:border-color var(--transition);outline:none}.input:focus,.textarea:focus,.select:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-muted)}.input::placeholder,.textarea::placeholder{color:var(--text-muted)}.textarea{resize:vertical;min-height:100px}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2394a3b8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2rem}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:.35rem;text-transform:uppercase;letter-spacing:.04em}.form-row{display:flex;gap:.75rem;align-items:flex-end}.badge{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .65rem;border-radius:100px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.badge-draft{background:#64748b26;color:#94a3b8}.badge-live{background:var(--success-muted);color:var(--success)}.badge-ended{background:#ef444426;color:#ef4444}.badge-type{background:var(--accent-muted);color:var(--accent-hover)}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.status-dot.visible{background:var(--success);box-shadow:0 0 6px #22c55e80}.status-dot.hidden{background:var(--text-muted)}.section{margin-bottom:2rem}.section-title{font-size:1.1rem;font-weight:600;margin-bottom:1rem;display:flex;align-items:center;justify-content:space-between}.event-detail-page{position:fixed;top:56px;left:0;right:0;bottom:0;display:grid;grid-template-columns:240px 1fr;overflow:hidden;z-index:1}.event-sidebar{background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;height:100%}.event-sidebar-header{padding:.85rem 1rem;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:.4rem;flex-shrink:0}.event-sidebar-title{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.event-sidebar-title h2{font-size:.95rem;font-weight:700;letter-spacing:-.01em;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-sidebar-actions{display:flex;gap:.4rem;flex-wrap:wrap}.event-sidebar-body{flex:1;overflow-y:auto}.event-main{display:flex;flex-direction:column;overflow:hidden;height:100%;background:var(--bg-primary)}.render-url-bar{display:flex;align-items:center;gap:.6rem;background:var(--bg-card);border-bottom:1px solid var(--border);padding:.5rem 1rem;flex-shrink:0}.render-url-bar .render-url-label{font-size:.72rem;font-weight:600;color:var(--accent-hover);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.render-url-bar .render-url-value{flex:1;font-size:.82rem;color:var(--text-primary);font-family:Cascadia Code,Fira Code,Consolas,monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;background:var(--bg-primary);padding:.3rem .6rem;border-radius:var(--radius-sm);border:1px solid var(--border)}.dual-preview{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;padding:.5rem 1rem;background:var(--bg-primary);flex-shrink:0;box-sizing:border-box}.preview-pane-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-weight:600;margin-bottom:4px}.preview-resize-handle{height:8px;flex-shrink:0;cursor:row-resize;background:var(--bg-card);border-top:1px solid var(--border);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;transition:background .15s}.preview-resize-handle:hover,.preview-resize-handle.dragging{background:color-mix(in srgb,var(--primary) 20%,var(--bg-card))}.preview-resize-handle:after{content:"";display:block;width:36px;height:3px;border-radius:2px;background:var(--border);box-shadow:0 -4px 0 var(--border),0 4px 0 var(--border)}.preview-resize-handle:hover:after,.preview-resize-handle.dragging:after{background:var(--primary);box-shadow:0 -4px 0 var(--primary),0 4px 0 var(--primary)}.event-editor-area{flex:1;overflow-y:auto;display:flex;flex-direction:column;min-height:0}.event-editor-tabs{display:flex;gap:.25rem;padding:.6rem 1rem 0;border-bottom:1px solid var(--border);background:var(--bg-card);flex-shrink:0}.event-editor-content{flex:1;padding:1rem;overflow-y:auto}.event-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.event-header h1{font-size:1.5rem;font-weight:700;letter-spacing:-.02em}.event-header .actions{margin-left:auto;display:flex;gap:.5rem}.event-layout{display:grid;grid-template-columns:340px 1fr;gap:1.5rem;align-items:start}@media (max-width: 900px){.event-detail-page{grid-template-columns:1fr;height:auto}.event-layout{grid-template-columns:1fr}}.panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.panel-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.panel-header h2{font-size:.95rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary)}.panel-body{padding:1.25rem}.panel-body-flush{padding:0}.overlay-list{list-style:none}.overlay-list-item{padding:.85rem 1.25rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.75rem;cursor:pointer;transition:background var(--transition)}.overlay-list-item:last-child{border-bottom:none}.overlay-list-item:hover{background:var(--bg-elevated)}.overlay-list-item.selected{background:var(--accent-muted);border-left:3px solid var(--accent)}.overlay-list-item .info{flex:1;min-width:0}.overlay-list-item .name{font-weight:500;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.overlay-list-item .meta{font-size:.8rem;color:var(--text-muted)}.editor-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:var(--text-muted);text-align:center}.editor-empty .icon{font-size:2rem;margin-bottom:.75rem;opacity:.4}.editor-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border)}.render-url-box{display:flex;align-items:center;gap:.5rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem .75rem;margin-top:1rem}.render-url-box code{flex:1;font-size:.8rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:Cascadia Code,Fira Code,Consolas,monospace}.create-form{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:1rem}.create-form h3{font-size:1rem;font-weight:600;margin-bottom:1rem}.template-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;transition:all var(--transition);cursor:pointer}.template-card:hover{border-color:#3d4160}.template-card.expanded{border-color:var(--accent)}.template-card .template-name{font-weight:600;font-size:1rem;margin-bottom:.35rem}.template-card .template-meta{display:flex;gap:.75rem;align-items:center;font-size:.85rem;color:var(--text-secondary)}.template-schema{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.template-schema pre{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:1rem;font-size:.8rem;overflow-x:auto;color:var(--text-secondary);font-family:Cascadia Code,Fira Code,Consolas,monospace}.checkbox-wrapper{display:flex;align-items:center;gap:.5rem;cursor:pointer}.checkbox-wrapper input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent);cursor:pointer}input[type=color].input{padding:.25rem;height:38px;cursor:pointer}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.empty-state p{margin-bottom:1rem}.copy-feedback{font-size:.8rem;color:var(--success);font-weight:500}.confirm-inline{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--danger)}.flex{display:flex}.flex-center{display:flex;align-items:center}.gap-sm{gap:.5rem}.gap-md{gap:1rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.text-muted{color:var(--text-muted)}.text-sm{font-size:.85rem}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#3d4160}.overlay-picker-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.overlay-picker-modal{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:1.5rem;width:90vw;max-width:720px;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #0006}.overlay-picker-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.overlay-picker-header h2{margin:0;font-size:1.2rem;font-weight:700}.overlay-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.overlay-picker-card{border:2px solid var(--border);border-radius:8px;overflow:hidden;cursor:pointer;transition:border-color .15s,transform .15s,box-shadow .15s;background:var(--bg)}.overlay-picker-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 16px #6366f133}.overlay-picker-preview{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;background:repeating-conic-gradient(#1a1a2e,#1a1a2e 25%,#12122a 0%,#12122a 50%) 0 0 / 12px 12px}.overlay-picker-info{padding:.6rem .75rem;border-top:1px solid var(--border)}.overlay-picker-name{font-weight:600;font-size:.9rem;margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.overlay-picker-meta{display:flex;align-items:center;gap:.5rem}.overlay-picker-confirm{display:flex;flex-direction:column;align-items:center}.overlay-picker-selected{text-align:center}
