:root{--dark-blue: #364B60;--light-blue: #C7D5E2;--white: #fff;--light-gray: #F0F0F0;--light-beige: #F1E1D1;--light-green: #BDD4CE;--code-bg: #1e1e1e;--code-font: #fff;--font-family: "Inter", "Segoe UI", "Arial", sans-serif}html,body{font-family:var(--font-family)}.console,code,pre{font-family:monospace}.text-common{font-family:var(--font-family);font-size:12px;color:var(--dark-blue)}.text-header{font-family:var(--font-family);font-size:14px;font-weight:700;color:var(--dark-blue)}.text-console{font-family:var(--font-family);font-size:12px;color:var(--white)}.btn{cursor:pointer;font-family:var(--font-family);font-size:14px;border-radius:5px;padding:8px 12px;margin:5px;border:2px solid var(--dark-blue);background:var(--light-beige);color:var(--dark-blue);transition:all .2s ease}.btn:hover{background:var(--white)}.btn-dark{background:var(--dark-blue);color:var(--white)}.btn-dark:hover{background:var(--white);color:var(--dark-blue)}.btn:disabled{background:var(--light-gray);color:var(--dark-blue);cursor:not-allowed}.btn-image{background:transparent;border:none;cursor:pointer;transition:transform .2s ease}.btn-image:hover{background:#00000021;transform:scale(1.1)}.menu{background:var(--dark-blue);color:var(--white);font-family:var(--font-family);font-size:14px;padding:10px;display:flex;gap:20px;height:40px;align-items:center;flex-shrink:0}.menu-item{cursor:pointer;padding:5px 10px}.menu-item:hover{background:var(--light-blue);border-radius:5px}.layout{display:flex;flex-direction:column;height:100vh;min-height:0;background:var(--light-gray)}.toolbar{display:flex;align-items:center;padding:5px 10px;background:var(--light-beige);border-bottom:1px solid var(--dark-blue);height:40px;flex-shrink:0}.main-content{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.splitter-pane{height:100%;min-height:0;display:flex;flex-direction:column}.sidebar{background:var(--light-beige);border-right:2px solid var(--light-blue);display:flex;flex-direction:column;min-width:150px;width:100%;height:100%;min-height:0;padding:10px 8px;box-sizing:border-box}.canvas-area{flex:1;background:var(--white);overflow:auto;position:relative;height:100%;min-height:0}.console{background:var(--code-bg);color:var(--code-font);padding:10px;font-family:monospace;overflow-y:auto;height:100%;min-height:0}.footer{background:var(--light-beige);text-align:center;padding:4px 16px;height:auto;min-height:32px;max-height:32px;flex-shrink:0;display:flex;align-items:center;justify-content:flex-end;border-top:1px solid var(--light-blue)}.workspace-footer{display:flex;justify-content:flex-end;align-items:center;padding:5px 10px;background:var(--light-beige);border-bottom:1px solid var(--dark-blue);height:40px;flex-shrink:0}.splitter{min-height:0;min-width:0}.splitter-divider{background:var(--light-blue);transition:background .2s}.splitter-divider:hover{background:var(--dark-blue)}.button-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:button-spin .6s linear infinite}@keyframes button-spin{to{transform:rotate(360deg)}}.language-selector{display:flex;align-items:center;position:relative}.language-select{padding:6px 28px 6px 30px;font-size:14px;font-family:var(--font-family, inherit);border:1px solid var(--light-blue, #e0e7ef);border-radius:4px;background-color:var(--white, #fff);color:var(--dark-blue, #2a3d50);cursor:pointer;transition:all .2s ease;outline:none;appearance:none;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='%232a3d50' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;background-size:12px;min-width:120px;font-weight:500}.language-select:hover{background-color:var(--light-gray, #f5f5f5);border-color:var(--dark-blue, #2a3d50)}.language-select:focus{border-color:var(--dark-blue, #2a3d50);box-shadow:0 0 0 2px #2a3d501a}.language-select option{background-color:var(--white, #fff);color:var(--dark-blue, #2a3d50);padding:8px}.language-selector-current{position:absolute;left:8px;top:50%;transform:translateY(-50%);pointer-events:none;font-size:16px;line-height:1}.navigation{background:var(--white);border-bottom:2px solid var(--light-blue);padding:0;position:sticky;top:0;z-index:1000;box-shadow:0 2px 4px #0000001a}.navigation-container{max-width:1200px;margin:0 auto;padding:12px 20px;display:flex;justify-content:space-between;align-items:center}.navigation-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--dark-blue);font-weight:700;font-size:18px;font-family:var(--font-family)}.logo-img{width:32px;height:32px}.navigation-links{display:flex;align-items:center;gap:20px}.nav-link{background:none;border:none;color:var(--dark-blue);font-family:var(--font-family);font-size:14px;cursor:pointer;padding:8px 12px;border-radius:4px;transition:background-color .2s;text-decoration:none}.nav-link:hover{background-color:var(--light-gray)}.nav-button{background:var(--dark-blue);color:var(--white);padding:8px 16px}.nav-button:hover{background:#2a3d50}.navigation-auth{display:flex;align-items:center;gap:10px;margin-left:10px;padding-left:10px;border-left:1px solid var(--light-blue)}.landing-page{min-height:100vh;background:var(--white)}.hero{background:linear-gradient(135deg,var(--light-blue) 0%,var(--light-beige) 100%);padding:80px 20px;text-align:center}.hero-content{max-width:800px;margin:0 auto}.hero-title{font-size:48px;font-weight:700;color:var(--dark-blue);margin-bottom:20px;font-family:var(--font-family)}.hero-subtitle{font-size:20px;color:var(--dark-blue);margin-bottom:40px;line-height:1.6;font-family:var(--font-family)}.hero-buttons{display:flex;gap:20px;justify-content:center;flex-wrap:wrap}.section{padding:60px 20px}.container{max-width:1200px;margin:0 auto}.section-title{font-size:36px;font-weight:700;color:var(--dark-blue);text-align:center;margin-bottom:40px;font-family:var(--font-family)}.about-section{background:var(--white)}.about-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px}.about-item{padding:30px;background:var(--light-gray);border-radius:8px;text-align:center}.about-item h3{font-size:24px;color:var(--dark-blue);margin-bottom:15px;font-family:var(--font-family)}.about-item p{font-size:16px;color:var(--dark-blue);line-height:1.6;font-family:var(--font-family)}.pricing-section{background:var(--light-gray)}.pricing-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px;margin-top:40px}.pricing-card{background:var(--white);border:2px solid var(--light-blue);border-radius:8px;padding:30px;text-align:center;position:relative;transition:transform .2s,box-shadow .2s}.pricing-card:hover{transform:translateY(-5px);box-shadow:0 4px 12px #0000001a}.pricing-card.featured{border-color:var(--dark-blue);border-width:3px}.pricing-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:var(--dark-blue);color:var(--white);padding:4px 16px;border-radius:12px;font-size:12px;font-weight:700}.pricing-image{width:100%;margin-bottom:20px;display:flex;justify-content:center;align-items:center}.pricing-image img{max-width:100%;max-height:200px;object-fit:contain;border-radius:8px}.pricing-card h3{font-size:24px;color:var(--dark-blue);margin-bottom:15px;font-family:var(--font-family)}.pricing-price{font-size:36px;font-weight:700;color:var(--dark-blue);margin-bottom:20px;font-family:var(--font-family)}.pricing-features{list-style:none;padding:0;margin:20px 0;text-align:left}.pricing-features li{padding:10px 0;color:var(--dark-blue);font-family:var(--font-family);border-bottom:1px solid var(--light-gray)}.pricing-features li:last-child{border-bottom:none}.contacts-section{background:var(--white)}.contacts-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px;margin-top:40px}.contact-item{text-align:center;padding:20px}.contact-item h3{font-size:20px;color:var(--dark-blue);margin-bottom:10px;font-family:var(--font-family)}.contact-item p{font-size:16px;color:var(--dark-blue);font-family:var(--font-family)}.contact-item a{color:var(--dark-blue);text-decoration:none;transition:color .2s}.contact-item a:hover{color:#2a3d50;text-decoration:underline}.footer{background:var(--dark-blue);color:var(--white);padding:30px 20px;text-align:center;font-family:var(--font-family)}.btn-primary{background:var(--dark-blue);color:var(--white);padding:12px 24px;font-size:16px;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s;font-family:var(--font-family)}.btn-primary:hover{background:#2a3d50}.btn-secondary{background:transparent;color:var(--dark-blue);padding:12px 24px;font-size:16px;border:2px solid var(--dark-blue);border-radius:6px;cursor:pointer;transition:background-color .2s;font-family:var(--font-family)}.btn-secondary:hover{background:var(--light-gray)}.btn-outline{background:transparent;color:var(--dark-blue);padding:12px 24px;font-size:16px;border:2px solid var(--dark-blue);border-radius:6px;cursor:pointer;transition:background-color .2s;font-family:var(--font-family);width:100%}.btn-outline:hover{background:var(--light-gray)}.login-page{min-height:100vh;background:linear-gradient(135deg,var(--light-blue) 0%,var(--light-beige) 100%)}.login-container{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 80px);padding:40px 20px}.login-card{background:var(--white);border-radius:12px;padding:40px;box-shadow:0 4px 12px #0000001a;max-width:400px;width:100%}.login-title{font-size:32px;font-weight:700;color:var(--dark-blue);margin-bottom:10px;text-align:center;font-family:var(--font-family)}.login-subtitle{font-size:16px;color:var(--dark-blue);margin-bottom:30px;text-align:center;font-family:var(--font-family)}.login-form,.form-group{margin-bottom:20px}.form-group label{display:block;font-size:14px;font-weight:700;color:var(--dark-blue);margin-bottom:8px;font-family:var(--font-family)}.form-group input{width:100%;padding:12px;font-size:16px;border:2px solid var(--light-blue);border-radius:6px;font-family:var(--font-family);box-sizing:border-box;transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--dark-blue)}.form-group input:disabled{background:var(--light-gray);cursor:not-allowed}.btn-block{width:100%;margin-top:10px}.error-message{background:#fee;color:#c33;padding:12px;border-radius:6px;margin-bottom:20px;font-family:var(--font-family);font-size:14px}.login-info{margin-top:20px;padding:15px;background:var(--light-gray);border-radius:6px;font-size:12px;color:var(--dark-blue);font-family:var(--font-family)}.login-info p{margin:5px 0}.login-info strong{font-weight:700}.checkbox-group{margin-top:20px}.checkbox-label{display:flex;align-items:flex-start;cursor:pointer;margin-bottom:10px;font-weight:400;line-height:1.5}.checkbox-label:last-child{margin-bottom:0}.checkbox-label:hover{opacity:.8}.checkbox-label input[type=checkbox]{width:auto;margin-right:10px;margin-top:3px;cursor:pointer;accent-color:var(--dark-blue);flex-shrink:0}.checkbox-label input[type=checkbox]:disabled{cursor:not-allowed;opacity:.6}.checkbox-text{font-size:14px;color:var(--dark-blue);font-family:var(--font-family)}.checkbox-link{color:#4a90e2;text-decoration:none;transition:color .2s}.checkbox-link:hover{color:var(--dark-blue);text-decoration:underline}.btn-primary:disabled{background:var(--light-gray);color:#999;cursor:not-allowed;opacity:.6}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--white);border-radius:8px;box-shadow:0 4px 20px #0000004d;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease;font-family:var(--font-family)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--light-gray)}.modal-title{font-size:24px;font-weight:700;color:var(--dark-blue);margin:0;font-family:var(--font-family)}.modal-close{background:none;border:none;font-size:32px;color:var(--dark-blue);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s;font-family:var(--font-family);line-height:1}.modal-close:hover{background:var(--light-gray)}.modal-form{padding:24px}.modal-field{margin-bottom:20px}.modal-label{display:block;font-size:14px;font-weight:600;color:var(--dark-blue);margin-bottom:8px;font-family:var(--font-family)}.modal-required{color:#ef4444}.modal-input,.modal-textarea{width:100%;padding:10px 12px;border:2px solid var(--light-blue);border-radius:6px;font-size:14px;font-family:var(--font-family);color:var(--dark-blue);box-sizing:border-box;transition:border-color .2s}.modal-input:focus,.modal-textarea:focus{outline:none;border-color:var(--dark-blue)}.modal-textarea{resize:vertical;min-height:100px}.modal-input::placeholder,.modal-textarea::placeholder{color:#364b6080}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid var(--light-gray)}.modal-btn{padding:10px 20px;border:2px solid var(--dark-blue);border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;font-family:var(--font-family)}.modal-btn--cancel{background:var(--white);color:var(--dark-blue)}.modal-btn--cancel:hover{background:var(--light-gray)}.modal-btn--create{background:var(--dark-blue);color:var(--white)}.modal-btn--create:hover:not(:disabled){background:var(--white);color:var(--dark-blue)}.modal-btn--create:disabled{background:var(--light-gray);color:#364b6080;cursor:not-allowed;border-color:var(--light-gray)}.dashboard-page{min-height:100vh;background:var(--white)}.dashboard-loading{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 80px);font-size:18px;color:var(--dark-blue);font-family:var(--font-family)}.dashboard-container{max-width:1200px;margin:0 auto;padding:40px 20px}.dashboard-header{margin-bottom:40px}.dashboard-title{font-size:36px;font-weight:700;color:var(--dark-blue);margin-bottom:20px;font-family:var(--font-family)}.user-info{padding:20px;background:var(--light-gray);border-radius:8px}.user-name{font-size:20px;font-weight:700;color:var(--dark-blue);margin:0 0 5px;font-family:var(--font-family)}.user-email{font-size:14px;color:var(--dark-blue);margin:0;font-family:var(--font-family)}.dashboard-content{margin-top:40px}.projects-section{margin-top:30px}.section-title{font-size:28px;font-weight:700;color:var(--dark-blue);margin-bottom:30px;font-family:var(--font-family)}.no-projects{text-align:center;padding:60px 20px;background:var(--light-gray);border-radius:8px}.no-projects p{font-size:18px;color:var(--dark-blue);margin-bottom:20px;font-family:var(--font-family)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.project-card{background:var(--white);border:2px solid var(--light-blue);border-radius:8px;padding:20px;cursor:pointer;transition:transform .2s,box-shadow .2s,border-color .2s}.project-card:hover{transform:translateY(-3px);box-shadow:0 4px 12px #0000001a;border-color:var(--dark-blue)}.project-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.project-card-actions{display:flex;align-items:center;gap:8px}.project-name{font-size:20px;font-weight:700;color:var(--dark-blue);margin:0;font-family:var(--font-family)}.project-badge{background:var(--dark-blue);color:var(--white);padding:4px 8px;border-radius:4px;font-size:12px;font-weight:700;font-family:var(--font-family)}.project-description{font-size:14px;color:var(--dark-blue);margin:0 0 15px;line-height:1.5;font-family:var(--font-family)}.project-footer{margin-top:15px;padding-top:15px;border-top:1px solid var(--light-gray)}.project-date{font-size:12px;color:var(--dark-blue);font-family:var(--font-family);opacity:.7}.project-card--new{border:2px dashed var(--light-blue);background:var(--light-gray);display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:200px}.project-card--new:hover{border-color:var(--dark-blue);background:#364b600d}.project-card-new-content{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;flex:1}.project-card-plus{font-size:48px;font-weight:700;color:var(--dark-blue);margin-bottom:15px;line-height:1;font-family:var(--font-family)}.project-card--new .project-name{color:var(--dark-blue)}.project-card--new .project-description{color:var(--dark-blue);margin:0;opacity:.8}.project-card--empty{opacity:.6;cursor:default}.project-card--empty:hover{transform:none;box-shadow:none}.project-action-btn{background:none;border:none;cursor:pointer;font-size:18px;padding:4px 8px;border-radius:4px;transition:background-color .2s,transform .2s;display:flex;align-items:center;justify-content:center;line-height:1;color:var(--dark-blue);opacity:.6}.project-action-btn svg{width:16px;height:16px}.project-action-btn:hover{background-color:#0000000d;transform:scale(1.1);opacity:1}.project-action-btn--edit:hover,.project-action-btn--delete:hover{background-color:#364b601a}.subscriptions-section{margin-bottom:40px}.subscriptions-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.subscription-card{background:var(--white);border:2px solid var(--light-blue);border-radius:8px;padding:20px;transition:transform .2s,box-shadow .2s,border-color .2s}.subscription-card:hover{transform:translateY(-3px);box-shadow:0 4px 12px #0000001a;border-color:var(--dark-blue)}.subscription-name{font-size:20px;font-weight:700;color:var(--dark-blue);margin:0 0 15px;font-family:var(--font-family)}.subscription-dates{display:flex;flex-direction:column;gap:8px}.subscription-dates p{font-size:14px;color:var(--dark-blue);margin:0;font-family:var(--font-family)}.subscription-dates strong{font-weight:700;margin-right:8px}.no-subscriptions{text-align:center;padding:40px 20px;background:var(--light-gray);border-radius:8px;border:2px dashed var(--light-blue)}.no-subscriptions p{font-size:16px;color:var(--dark-blue);margin:0;font-family:var(--font-family);opacity:.7}html,body,#root{height:100%;margin:0;padding:0}#workspace{width:100%;height:100%}.sidebar-tree{font-family:Segoe UI,sans-serif;font-size:14px;color:#1e2a45;background:#f7f5ef;height:100%;padding:6px;box-sizing:border-box}.tree-search{width:100%;margin-bottom:8px;padding:6px 8px;font-size:13px;border:1px solid #ccc;border-radius:4px}.tree-folder-header{cursor:pointer;font-weight:700;margin:2px 0;display:flex;align-items:center}.tree-folder-icon{margin-right:4px}.tree-children{margin-left:16px}.tree-node{margin:3px 0}.tree-node-card{background:#fff;border:1px solid #1e2a45;border-radius:3px;padding:4px 6px;width:200px;cursor:grab;transition:background .2s,box-shadow .2s}.tree-node-card:hover{background:#eef2f9;box-shadow:0 0 4px #0003}.tree-node-header{font-weight:600;margin-bottom:2px;font-size:14px;color:#1e2a45}.tree-node-text{font-size:12px;color:#555}.dragging{opacity:.4}.react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:-webkit-grab;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:#3367d9;border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.node-shell{min-width:200px;background:#fdfdfd;border:1px solid #364b60;border-radius:8px;box-shadow:0 2px 4px #00000014;font-family:Segoe UI,system-ui,-apple-system,sans-serif;color:#1d2a3a;transition:box-shadow .2s ease,border-width .2s ease}.node-shell--selected{box-shadow:0 0 0 3px #3b82f64d,0 2px 8px #00000026;border-width:2px}.node-shell__header{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;border-bottom:1px solid #d7dee7;border-radius:8px 8px 0 0;background:#eef2f7;font-weight:600;font-size:14px}.node-shell__body{padding:12px 20px 12px 10px;font-size:13px;gap:6px;display:flex;flex-direction:column}.node-input-list{display:flex;flex-direction:column;gap:4px;margin-bottom:6px}.node-input-list__row{width:100%}.node-handle-button{position:relative;width:100%;padding:4px 10px 4px 14px;border:1px solid #d7dee7;border-radius:6px;background:#f8fafc;font-size:12px;color:#1d2a3a;cursor:default;display:flex;align-items:center;gap:6px}.node-handle-button:hover{background:#eef2f7}.node-handle-button:after{content:attr(data-label);pointer-events:none}.node-handle-button.node-handle-button--left{width:50%;max-width:100px;height:15px;justify-content:flex-start}.node-handle-button.node-handle-button--right{position:absolute;top:50%;right:-20px;transform:translateY(-50%);width:25px;height:15px;justify-content:center}.watch-node__viewer{font-size:12px;max-height:220px;overflow:auto;border:1px solid #d7dee7;border-radius:6px;padding:6px;background:#fdfdfd}.watch-node__item{margin-bottom:4px}.watch-node__label{display:flex;align-items:center;gap:6px;background:#eef2f7;border:1px solid #d7dee7;border-radius:4px;padding:2px 6px;cursor:pointer}.watch-node__index{font-size:11px;color:#4a5568;background:#edf2f7;border-radius:4px;padding:0 4px}.watch-node__chevron{margin-left:auto;font-size:10px;color:#4a5568}.watch-node__children{border-left:1px solid #d7dee7;margin-left:12px;padding-left:10px;padding-top:4px}.watch-node__value{font-family:Consolas,Fira Code,monospace}.watch-node__empty{color:#6b7280;font-style:italic}.node-context-menu{position:fixed!important;z-index:10000!important;min-width:180px;background:#fff!important;border:1px solid #364b60;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:4px 0;font-size:13px;font-family:Segoe UI,system-ui,-apple-system,sans-serif;-webkit-user-select:none;user-select:none;pointer-events:auto;color:#1d2a3a}.node-context-menu__item{padding:8px 14px;cursor:pointer;transition:background-color .15s ease;color:#1d2a3a}.node-context-menu__item:hover{background:#eef2f7}.node-context-menu__item:active{background:#d7dee7}.node-input-list__empty{font-size:12px;color:#6b7c92}.node-shell__footer{border-top:1px solid #d7dee7;padding:6px 10px;font-size:12px;color:#5a6d82;background:#f7f9fc;border-radius:0 0 8px 8px}.node-shell__badge{font-size:11px;padding:2px 6px;border-radius:999px;background:#dfe8ff;color:#1f3d8f}.node-shell__input-row{display:flex;justify-content:space-between;font-size:12px;color:#44566b}.node-shell__controls{display:flex;gap:4px}.node-shell__controls button{padding:2px 6px;font-size:12px;border:1px solid #d7dee7;border-radius:4px;background:#fff;cursor:pointer}.node-shell__controls button:hover{background:#f0f4fa}.node-shell__textarea{width:100%;min-height:60px;border:1px solid #d7dee7;border-radius:6px;padding:6px;font-family:Consolas,Fira Code,monospace;font-size:12px;resize:both}.node-shell__range{width:100%}.node-shell__highlight{font-weight:600;color:#1f3d8f}.node-shell__expander{display:flex;align-items:center;justify-content:space-between;width:100%;padding:4px 6px;border:1px solid #d7dee7;border-radius:6px;background:#f4f7fb;cursor:pointer;font-size:12px;gap:6px}.node-shell__expander:hover{background:#e7edf6}.node-shell__expander-arrow{transition:transform .15s ease;display:inline-flex;width:12px;justify-content:center}.node-shell__expander-arrow--open{transform:rotate(90deg)}.node-shell-wrapper{position:relative;padding:4px}.node-error-banner{position:absolute;top:0;left:0;right:0;transform:translateY(-100%);margin-bottom:4px;background:#fee2e2;border:1px solid #fca5a5;border-radius:6px;padding:6px 10px;font-size:12px;color:#991b1b;z-index:10;box-shadow:0 2px 4px #0000001a;white-space:pre-wrap;word-break:break-word;max-width:100%;max-height:200px;overflow-y:auto;overflow-x:hidden}.node-executing-indicator{position:absolute;top:-35px;left:0;right:0;background:#dbeafe;border:1px solid #60a5fa;border-radius:6px;padding:4px 10px;font-size:12px;color:#1e40af;z-index:10;box-shadow:0 2px 4px #0000001a;display:flex;align-items:center;gap:8px}.node-executing-spinner{width:12px;height:12px;border:2px solid #bfdbfe;border-top-color:#3b82f6;border-radius:50%;animation:node-spin .6s linear infinite}@keyframes node-spin{to{transform:rotate(360deg)}}.node-shell--executing{opacity:.9;box-shadow:0 0 0 2px #3b82f64d,0 2px 8px #00000026}.notification{position:fixed;top:20px;right:20px;min-width:300px;max-width:500px;background:var(--white);border-radius:8px;box-shadow:0 4px 12px #00000026;padding:16px 20px;z-index:10000;transform:translate(400px);opacity:0;transition:transform .3s ease-out,opacity .3s ease-out;font-family:var(--font-family)}.notification--visible{transform:translate(0);opacity:1}.notification--exiting{transform:translate(400px);opacity:0}.notification--success{border-left:4px solid #28a745}.notification--error{border-left:4px solid #dc3545}.notification--info{border-left:4px solid #17a2b8}.notification-content{display:flex;align-items:center;justify-content:space-between;gap:12px}.notification-message{flex:1;color:var(--dark-blue);font-size:14px;line-height:1.5;font-family:var(--font-family)}.notification-close{background:none;border:none;color:var(--dark-blue);font-size:24px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;line-height:1;opacity:.6;transition:opacity .2s;font-family:var(--font-family)}.notification-close:hover{opacity:1}.spa-preview-container{width:100%;height:100%;min-height:400px;overflow:hidden;position:relative;background-color:var(--bg-color, #F0F0F0);box-sizing:border-box}@media (max-width: 768px){.spa-preview-container{min-height:300px}}iframe .spa-preview-container{height:100%;min-height:auto}.admin-page{min-height:100vh;background:var(--light-gray, #f5f5f5)}.admin-container{max-width:1200px;margin:0 auto;padding:40px 20px}.admin-header{text-align:center;margin-bottom:40px}.admin-header h1{font-size:36px;font-weight:700;color:var(--dark-blue, #1a3a5f);margin-bottom:10px;font-family:var(--font-family, sans-serif)}.admin-header p{font-size:18px;color:var(--dark-blue, #1a3a5f);font-family:var(--font-family, sans-serif)}.admin-loading{text-align:center;padding:40px;font-size:18px;color:var(--dark-blue, #1a3a5f)}.admin-models-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}.admin-model-card{background:var(--white, #ffffff);border:2px solid var(--light-blue, #e3f2fd);border-radius:12px;padding:24px;cursor:pointer;transition:all .2s ease;position:relative;min-height:120px;display:flex;flex-direction:column;justify-content:space-between}.admin-model-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001a;border-color:var(--dark-blue, #1a3a5f)}.admin-model-card h3{font-size:24px;font-weight:700;color:var(--dark-blue, #1a3a5f);margin-bottom:8px;font-family:var(--font-family, sans-serif)}.admin-model-description{font-size:14px;color:#666;margin:0;line-height:1.5;font-family:var(--font-family, sans-serif)}.admin-model-arrow{position:absolute;bottom:24px;right:24px;font-size:24px;color:var(--dark-blue, #1a3a5f);transition:transform .2s ease}.admin-model-card:hover .admin-model-arrow{transform:translate(4px)}.admin-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.admin-modal{background:var(--white, #ffffff);border-radius:12px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #0000004d}.admin-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--light-gray, #f5f5f5)}.admin-modal-header h2{font-size:24px;font-weight:700;color:var(--dark-blue, #1a3a5f);margin:0;font-family:var(--font-family, sans-serif)}.admin-modal-close{background:none;border:none;font-size:32px;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.admin-modal-close:hover{color:var(--dark-blue, #1a3a5f)}.admin-form{padding:24px}.admin-form-field{margin-bottom:20px}.admin-form-field label{display:block;margin-bottom:8px;font-weight:700;color:var(--dark-blue, #1a3a5f);font-family:var(--font-family, sans-serif)}.admin-required{color:#c62828;margin-left:4px}.admin-form-field input[type=text],.admin-form-field input[type=email],.admin-form-field input[type=number],.admin-form-field input[type=datetime-local],.admin-form-field textarea,.admin-form-field select{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;font-family:var(--font-family, sans-serif);transition:border-color .2s ease}.admin-form-field input:focus,.admin-form-field textarea:focus,.admin-form-field select:focus{outline:none;border-color:var(--dark-blue, #1a3a5f)}.admin-form-field input[type=checkbox]{width:auto;margin-right:8px}.admin-readonly-field{padding:10px 12px;background:var(--light-gray, #f5f5f5);border-radius:6px;color:#666;font-family:var(--font-family, sans-serif)}.admin-hint{font-size:12px;color:#666;margin:4px 0;font-style:italic;font-family:var(--font-family, sans-serif)}.admin-form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:24px;border-top:1px solid var(--light-gray, #f5f5f5)}.admin-form-actions button{padding:10px 24px;border:none;border-radius:6px;cursor:pointer;font-size:16px;font-weight:700;transition:all .2s ease;font-family:var(--font-family, sans-serif)}.admin-form-actions button[type=button]{background:var(--light-gray, #f5f5f5);color:var(--dark-blue, #1a3a5f)}.admin-form-actions button[type=button]:hover:not(:disabled){background:#e0e0e0}.admin-form-actions button[type=submit]{background:var(--dark-blue, #1a3a5f);color:var(--white, #ffffff)}.admin-form-actions button[type=submit]:hover:not(:disabled){background:#2a3d50}.admin-form-actions button:disabled{opacity:.5;cursor:not-allowed}.admin-file-upload-area{display:flex;flex-direction:column;gap:12px}.admin-file-drop-zone{border:2px dashed #ccc;border-radius:8px;padding:40px 20px;text-align:center;cursor:pointer;transition:all .2s ease;background:var(--light-gray, #f5f5f5)}.admin-file-drop-zone:hover{border-color:var(--dark-blue, #1a3a5f);background:#e8f4f8}.admin-file-drop-zone.admin-drag-over{border-color:var(--dark-blue, #1a3a5f);background:#d0e8f0;transform:scale(1.02)}.admin-file-upload-label{cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:12px}.admin-file-upload-icon{font-size:48px}.admin-file-upload-label strong{color:var(--dark-blue, #1a3a5f);font-size:16px;font-family:var(--font-family, sans-serif)}.admin-file-upload-hint{font-size:12px;color:#666;font-family:var(--font-family, sans-serif)}.admin-multiselect{width:100%}.admin-multiselect-list{max-height:300px;overflow-y:auto;border:1px solid #ddd;border-radius:6px;padding:8px;background:var(--white, #ffffff)}.admin-multiselect-item{display:flex;align-items:center;padding:8px 12px;cursor:pointer;border-radius:4px;transition:background-color .2s ease;font-family:var(--font-family, sans-serif)}.admin-multiselect-item:hover{background-color:var(--light-gray, #f5f5f5)}.admin-multiselect-item input[type=checkbox]{margin-right:10px;cursor:pointer;width:18px;height:18px}.admin-multiselect-item span{flex:1;color:var(--dark-blue, #1a3a5f);font-size:14px}.admin-list-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;gap:20px}.admin-list-header h1{font-size:32px;font-weight:700;color:var(--dark-blue, #1a3a5f);margin:0 0 8px;font-family:var(--font-family, sans-serif)}.admin-back-button{background:transparent;color:var(--dark-blue, #1a3a5f);border:1px solid var(--dark-blue, #1a3a5f);padding:8px 16px;border-radius:6px;cursor:pointer;margin-bottom:16px;font-size:14px;transition:all .2s ease;font-family:var(--font-family, sans-serif)}.admin-back-button:hover{background:var(--light-gray, #f5f5f5)}.admin-create-button{background:var(--dark-blue, #1a3a5f);color:var(--white, #ffffff);border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:16px;font-weight:700;transition:background-color .2s ease;font-family:var(--font-family, sans-serif);white-space:nowrap}.admin-create-button:hover{background:#2a3d50}.admin-table-container{overflow-x:auto;background:var(--white, #ffffff);border-radius:8px;box-shadow:0 2px 4px #0000001a}.admin-table{width:100%;border-collapse:collapse;font-family:var(--font-family, sans-serif)}.admin-table thead{background:var(--light-gray, #f5f5f5)}.admin-table th{padding:12px 16px;text-align:left;font-weight:700;color:var(--dark-blue, #1a3a5f);border-bottom:2px solid var(--light-blue, #e3f2fd)}.admin-table td{padding:12px 16px;border-bottom:1px solid var(--light-gray, #f5f5f5);color:var(--dark-blue, #1a3a5f)}.admin-table tbody tr:hover{background:var(--light-gray, #f5f5f5)}.admin-empty{text-align:center;color:#999;padding:40px!important}.admin-actions{display:flex;gap:8px}.admin-edit-button,.admin-delete-button{padding:6px 12px;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s ease;font-family:var(--font-family, sans-serif)}.admin-edit-button{background:var(--light-blue, #e3f2fd);color:var(--dark-blue, #1a3a5f)}.admin-edit-button:hover{background:#b3d9ff}.admin-delete-button{background:#ffebee;color:#c62828}.admin-delete-button:hover{background:#ffcdd2}.admin-pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:24px;font-family:var(--font-family, sans-serif)}.admin-pagination button{padding:8px 16px;border:1px solid var(--dark-blue, #1a3a5f);background:var(--white, #ffffff);color:var(--dark-blue, #1a3a5f);border-radius:6px;cursor:pointer;transition:all .2s ease}.admin-pagination button:hover:not(:disabled){background:var(--light-gray, #f5f5f5)}.admin-pagination button:disabled{opacity:.5;cursor:not-allowed}.admin-pagination span{color:var(--dark-blue, #1a3a5f)}.admin-current-user-hint{color:#666;font-style:italic;font-size:14px;font-family:var(--font-family, sans-serif)}
