@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700&family=Roboto:wght@400;700&family=Open+Sans:wght@400;700&family=Lato:wght@400;700&family=Montserrat:wght@400;700&family=Poppins:wght@400;700&family=Nunito:wght@400;700&display=swap";*{box-sizing:border-box}body{margin:0;font-family:Inter,Arial,sans-serif;background:#f1f4fb;color:#111827}#app{min-height:100vh}.app-shell{display:grid;grid-template-columns:1fr 1fr;gap:14px;min-height:100vh;padding:14px}.left-panel,.right-panel{background:#fff;border:1px solid #dde2ee;border-radius:12px;padding:12px;display:flex;flex-direction:column;min-height:calc(100vh - 28px)}.left-panel{max-height:calc(100vh - 28px);overflow-y:auto;overflow-x:hidden;padding-top:0;background:#1e1e1e;border-color:#2a2d2e}.left-panel .panel-header h2{color:#d4d4d4}.left-panel .panel-header p{color:#9da1a6}.right-panel{background:#1e1e1e;border-color:#2a2d2e}.right-panel .panel-header h2{color:#d4d4d4}.right-panel .panel-header p{color:#9da1a6}.left-top{position:sticky;top:0;z-index:20;background:linear-gradient(180deg,#1e1e1e 82%,#1e1e1eeb);padding:12px 0 10px;border-bottom:1px solid #2f3336}.left-panel .toolbar button{background:#252526;border-color:#3c3c3c;color:#d4d4d4;box-shadow:none}.left-panel .toolbar button:hover{background:#2d2d30;border-color:#4b4b4b;transform:none}.left-panel .toolbar button.toggle-active{background:#0b5cad;border-color:#1d4ed8;color:#fff}.left-panel .toolbar button.toggle-active:hover{background:#1d4ed8;border-color:#2563eb}.left-panel .toolbar button[data-action=add-page]{background:#007acc;border-color:#0068ad}.left-panel .toolbar button[data-action=add-page]:hover{background:#0068ad;border-color:#00578f}.left-panel .danger-btn{border-color:#6b2d32;background:#3a1f23;color:#ffb4b4}.left-panel .danger-btn:hover{background:#4a252a;border-color:#8a3a41}.panel-header h2{margin:0;font-size:22px;letter-spacing:-.01em;color:#0f172a}.panel-header p{margin:5px 0 0;color:#475569;font-size:13px}.toolbar{margin-top:12px;display:flex;flex-wrap:wrap;gap:10px}button{border:1px solid #c6cfdf;background:#f8fbff;color:#1f2937;border-radius:10px;padding:8px 12px;font-size:13px;font-weight:500;cursor:pointer;transition:all .16s ease;box-shadow:0 1px #0f172a08}button:hover{background:#eef4ff;border-color:#aebbd4;transform:translateY(-1px)}.toolbar button[data-action=add-page]{background:#2563eb;color:#fff;border-color:#1d4ed8}.toolbar button[data-action=add-page]:hover{background:#1d4ed8;border-color:#1e40af}.danger-btn{border-color:#f2bebe;background:#fff7f7;color:#b91c1c}.danger-btn:hover{background:#ffe8e8;border-color:#e79e9e}.canvas-wrap{margin-top:12px;padding:10px;background:#fff;border:1px dashed #cfd6e3;border-radius:10px;overflow:auto}.canvas{width:794px;min-height:1123px;margin:0 auto;position:relative;background:#fff;border:1px solid #d5dbea}.canvas-page-separator{position:absolute;left:0;right:0;height:18px;transform:translateY(-9px);background:linear-gradient(to bottom,#cbd5e100,#cbd5e1a6,#cbd5e100);pointer-events:none;z-index:0}.canvas-page-number{position:absolute;right:12px;font-size:11px;color:#64748b;background:#ffffffd9;padding:2px 6px;border-radius:4px;pointer-events:none;z-index:2}.canvas-guide{position:absolute;pointer-events:none;z-index:1}.canvas-guide.center{background:#94a3b873}.canvas-guide.center-h{left:0;right:0;top:50%;height:1px}.canvas-guide.center-v{top:0;bottom:0;left:50%;width:1px}.canvas-guide.cross{background:#2563ebcc;opacity:0;transition:opacity .06s ease}.canvas-guide.cross.visible{opacity:1}.canvas-guide.cross-h{left:0;right:0;height:1px}.canvas-guide.cross-v{top:0;bottom:0;width:1px}.canvas-guide.center.active{background:#2563ebf2}.canvas-el{position:absolute;border:1px solid #6b7280;background:#0f172a08;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:11px;color:#1f2937;padding:4px;overflow:hidden;text-align:center;-webkit-user-select:none;user-select:none;touch-action:none}.table-canvas-el{padding:0;align-items:stretch;justify-content:stretch;background:#fff}.canvas-table-preview{width:100%;height:100%;position:relative;overflow:hidden}.canvas-table{width:100%;height:100%;border-collapse:collapse;table-layout:fixed;font-size:10px}.canvas-table th,.canvas-table td{border:1px solid #9ca3af;padding:3px 4px;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.canvas-table thead th{background:#eef2ff}.canvas-el.selected{border:2px solid #2563eb;background:#2563eb1a}.table-canvas-el.selected{background:#fff}.resize-handle{position:absolute;right:-6px;bottom:-6px;width:12px;height:12px;border:1px solid #1d4ed8;background:#fff;border-radius:2px;cursor:nwse-resize;padding:0}.table-col-handle{position:absolute;top:0;transform:translate(-50%);width:10px;height:100%;border:0;padding:0;background:transparent;border-left:2px solid rgba(37,99,235,.75);cursor:col-resize}.table-action-btn{position:absolute;width:18px;height:18px;border:1px solid #1d4ed8;border-radius:999px;background:#2563eb;color:#fff;font-size:13px;line-height:1;display:flex;align-items:center;justify-content:center;padding:0;z-index:3}.table-action-btn:hover{background:#1d4ed8}.table-action-top-right{top:6px;right:6px}.table-action-bottom-left{bottom:6px;left:6px}.props-panel{margin-top:12px;border-top:1px solid #e5eaf4;padding-top:10px}.properties-popup{position:fixed;width:min(370px,calc(100vw - 20px));max-height:min(80vh,680px);background:#fff;border:1px solid #d8dfec;border-radius:12px;box-shadow:0 24px 60px #0f172a40;z-index:950;display:flex;flex-direction:column}.properties-popup-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 12px;border-bottom:1px solid #e4e9f3;background:#f8faff;border-radius:12px 12px 0 0;cursor:move;-webkit-user-select:none;user-select:none}.properties-popup-header h3{margin:0;font-size:14px}.properties-popup-header button{min-width:28px;width:28px;height:28px;border-radius:8px;padding:0;line-height:1}.properties-popup-body{padding:10px 12px;overflow:auto}.props-panel h3,.preview-wrap h3{margin:0 0 8px;font-size:14px}.props-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:#374151;margin-bottom:8px}input,textarea,select{border:1px solid #c4cce0;border-radius:8px;padding:7px 9px;font-size:12px;width:100%}.empty-state{margin:0;color:#6b7280;font-size:12px}.code-tabs{margin-top:10px;display:flex;gap:8px}.code-tabs button{background:#252526;border-color:#3c3c3c;color:#c8c8c8;border-radius:6px;box-shadow:none}.code-tabs button:hover{background:#2d2d30;border-color:#4b4b4b;transform:none}.right-top-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.right-header{flex:0 1 auto;min-width:140px}.code-lang-row{margin-top:0;padding:10px 12px;border:1px solid #3c3c3c;border-radius:12px;background:#252526;min-width:280px}.code-lang-row-parallel{display:flex;flex-wrap:wrap;align-items:flex-end;gap:12px 16px}.code-lang-row-parallel .code-lang-main{flex:1 1 140px;min-width:140px;margin-top:0}.code-lang-row-parallel .code-lang-help{flex:1 1 100%;margin-top:4px;margin-bottom:0}.code-lang-main{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:10px}.code-lang-main+.code-lang-main{margin-top:8px}.code-lang-label{margin:0;font-size:12px;font-weight:700;color:#d4d4d4;white-space:nowrap;line-height:1}.code-lang-select-wrap{position:relative;width:100%}.code-lang-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;height:40px;width:100%;padding-right:36px;border-color:#3c3c3c;background:#1e1e1e;color:#d4d4d4;font-weight:600}.code-lang-select:hover{border-color:#4b4b4b}.code-lang-select:focus{outline:none;border-color:#007acc;box-shadow:0 0 0 2px #007acc33}.code-lang-chevron{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:12px;color:#9da1a6;pointer-events:none}.code-lang-help{margin:7px 0 0;font-size:11px;color:#9da1a6}.set-role-wrap{display:flex;align-items:center;gap:8px;margin-bottom:8px}.set-role-menu{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.role-tag{font-size:11px;color:#475569;background:#f1f5f9;border:1px solid #dbe4ef;border-radius:999px;padding:2px 8px}.code-tabs .active{border-color:#007acc;background:#094771;color:#fff}.code-editor-wrap{margin-top:10px;position:relative;border:1px solid #3c3c3c;border-radius:8px;overflow:hidden;min-height:290px;background:#1e1e1e}#code-highlight,#code-editor{margin:0;width:100%;min-height:290px;padding:7px 9px;font-family:Consolas,Courier New,monospace;font-size:13px;line-height:1.5;white-space:pre;tab-size:2}#code-highlight{position:absolute;inset:0;overflow:hidden;pointer-events:none;color:#d4d4d4}#code-editor{position:relative;z-index:2;resize:vertical;border:0;border-radius:0;background:transparent;color:transparent;-webkit-text-fill-color:transparent;caret-color:#fff;text-shadow:none;overflow:auto}#code-editor::selection{background:#264f78bf;color:transparent}.code-editor-wrap.editing #code-highlight{opacity:0}.code-editor-wrap.editing #code-editor{color:#d4d4d4;-webkit-text-fill-color:#d4d4d4}.code-editor-wrap.editing #code-editor::selection{background:#264f78bf;color:#fff;-webkit-text-fill-color:#ffffff}.tok-comment{color:#6a9955}.tok-string{color:#ce9178}.tok-keyword{color:#c586c0}.tok-tag{color:#569cd6}.tok-attr{color:#9cdcfe}.tok-number{color:#b5cea8}.tok-template{color:#dcdcaa}.tok-punct{color:gray}.preview-wrap{margin-top:12px;border-top:1px solid #2f3336;display:flex;flex-direction:column;flex:1;background:#252526;border:1px solid #3c3c3c;border-radius:10px;padding:10px}.preview-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.preview-header h3{margin:0;color:#d4d4d4}.right-panel .preview-header button{background:#2d2d30;border-color:#3c3c3c;color:#d4d4d4;box-shadow:none}.right-panel .preview-header button:hover{background:#36363a;border-color:#4b4b4b;transform:none}#preview-frame{width:100%;flex:1;min-height:320px;border:1px solid #3c3c3c;border-radius:8px;background:#fff}.preview-modal-overlay{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;padding:18px;z-index:999}.preview-modal{width:min(1200px,100%);height:min(92vh,980px);background:#1e1e1e;border-radius:12px;border:1px solid #3c3c3c;display:flex;flex-direction:column;padding:12px}.preview-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.preview-modal-header h3{margin:0;font-size:16px;color:#d4d4d4}.preview-modal-header button{background:#2d2d30;border-color:#3c3c3c;color:#d4d4d4;box-shadow:none}.preview-modal-header button:hover{background:#36363a;border-color:#4b4b4b;transform:none}#preview-modal-frame{width:100%;height:100%;border:1px solid #3c3c3c;border-radius:8px;background:#fff}@media(max-width:1250px){.app-shell{grid-template-columns:1fr}}
