*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #2563eb;--primary-hover: #1d4ed8;--secondary: #64748b;--success: #10b981;--warning: #f59e0b;--error: #ef4444;--bg: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--text-primary: #1e293b;--text-secondary: #64748b;--border: #e2e8f0;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1)}html{font-size:14px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--text-primary);background-color:var(--bg);line-height:1.6}.login-container{min-height:100vh;display:flex;flex-direction:column}.login-header{padding:1.5rem 2rem;border-bottom:1px solid var(--border)}.logo{display:flex;align-items:center;gap:.75rem;font-size:1.5rem;font-weight:600;color:var(--primary)}.logo-icon{width:32px;height:32px;color:var(--primary)}.logo-text{color:var(--text-primary)}.login-main{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--bg-secondary)}.login-card{background:var(--bg);border-radius:.75rem;padding:2.5rem;width:100%;max-width:540px;box-shadow:var(--shadow-lg)}.login-title{font-size:2rem;font-weight:700;margin-bottom:.5rem;color:var(--text-primary)}.login-subtitle{color:var(--text-secondary);margin-bottom:2rem}.login-form{margin-bottom:1.5rem}.form-group{margin-bottom:1.25rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:.5rem}.form-input{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:.5rem;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.password-input-wrapper{position:relative}.password-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:.25rem}.eye-icon{width:20px;height:20px}.form-footer{display:flex;justify-content:flex-end;margin-bottom:1.5rem}.forgot-password{color:var(--primary);text-decoration:none;font-size:.875rem}.forgot-password:hover{text-decoration:underline}.btn{padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn-full{width:100%}.btn-primary{background-color:var(--primary);color:#fff}.btn-primary:hover{background-color:var(--primary-hover)}.btn-secondary{background-color:var(--bg);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background-color:var(--bg-secondary)}.btn-outline{background-color:transparent;color:var(--text-primary);border:1px solid var(--border)}.btn-outline:hover{background-color:var(--bg-secondary)}.aws-icon{width:20px;height:20px}.divider{display:flex;align-items:center;gap:1rem;margin:1.5rem 0;color:var(--text-secondary)}.divider-line{flex:1;height:1px;background:var(--border)}.signup-link{text-align:center;margin-top:1.5rem;color:var(--text-secondary)}.signup-link .link{color:var(--primary);text-decoration:none;font-weight:500}.signup-link .link:hover{text-decoration:underline}.checkbox-label{display:flex;align-items:flex-start;gap:.5rem;font-size:.875rem;color:var(--text-secondary);cursor:pointer}.checkbox-label input[type=checkbox]{margin-top:.125rem;cursor:pointer;width:1rem;height:1rem;accent-color:var(--primary)}.checkbox-label .link{color:var(--primary);text-decoration:none}.checkbox-label .link:hover{text-decoration:underline}.aws-header{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:.5rem}.aws-logo{width:40px;height:40px}.form-hint{display:block;font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}.alternative-options{margin-top:1rem}.aws-info-box{margin-top:2rem;padding:1.5rem;background:var(--bg-secondary);border-radius:.5rem;border:1px solid var(--border)}.info-title{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem}.info-list{list-style:none;padding:0;margin:0}.info-list li{font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem;padding-left:1.25rem;position:relative}.info-list li:before{content:"•";position:absolute;left:0;color:var(--primary);font-weight:700}.info-list li:last-child{margin-bottom:0}.app-container{display:flex;height:100vh;max-width:100vw;overflow:hidden}.sidebar{flex-shrink:0;width:200px;background:var(--bg);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto}.sidebar-header{padding:1.5rem;border-bottom:1px solid var(--border)}.sidebar-nav{flex:1;padding:1rem 0}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;color:var(--text-secondary);text-decoration:none;transition:all .2s}.nav-item:hover{background:var(--bg-secondary);color:var(--text-primary)}.nav-item.active{background:var(--bg-secondary);color:var(--primary);border-right:3px solid var(--primary)}.nav-icon{width:20px;height:20px}.sidebar-footer{padding:1rem 1.5rem 1.25rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.75rem}.btn-logout{display:flex;align-items:center;gap:.5rem;width:100%;padding:.45rem .75rem;border:1px solid var(--border);border-radius:.375rem;background:transparent;color:var(--text-secondary);font-size:.8125rem;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.btn-logout svg{width:.9rem;height:.9rem;flex-shrink:0}.btn-logout:hover{background:#fef2f2;color:var(--error);border-color:var(--error)}.user-profile{display:flex;align-items:center;gap:.75rem}.user-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem}.user-avatar-small{width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.75rem}.user-name{font-weight:500;font-size:.875rem}.user-email{font-size:.75rem;color:var(--text-secondary)}.main-content{flex:1;display:flex;flex-direction:column;background:var(--bg-secondary)}.top-bar{background:var(--bg);border-bottom:1px solid var(--border);padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between}.search-bar{display:flex;align-items:center;gap:.75rem;background:var(--bg-secondary);padding:.5rem 1rem;border-radius:.5rem;border:1px solid var(--border);flex:1;max-width:400px}.search-icon{width:20px;height:20px;color:var(--text-secondary)}.search-input{border:none;background:transparent;flex:1;outline:none;font-size:.875rem}.top-bar-actions{display:flex;align-items:center;gap:1rem}.icon-button{background:none;border:none;cursor:pointer;padding:.5rem;color:var(--text-secondary);border-radius:.5rem;transition:background .2s}.icon-button:hover{background:var(--bg-secondary)}.icon{width:20px;height:20px}.content-area{flex:1;padding:2rem;overflow-y:auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-title{font-size:1.875rem;font-weight:700;color:var(--text-primary)}.btn-icon{width:18px;height:18px}.table-container{background:var(--bg);border-radius:.5rem;border:1px solid var(--border);overflow:hidden}.projects-table{width:100%;border-collapse:collapse}.projects-table thead{background:var(--bg-secondary)}.projects-table th{padding:1rem;text-align:left;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.projects-table td{padding:1rem;border-top:1px solid var(--border);color:var(--text-primary)}.action-links{display:flex;gap:.5rem;align-items:center}.action-link{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .75rem;font-size:.8rem;font-weight:500;border-radius:.375rem;border:1px solid var(--primary);color:var(--primary);background:transparent;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.action-link:hover{background:var(--primary);color:#fff;text-decoration:none}.action-link-danger{border-color:var(--error);color:var(--error)}.action-link-danger:hover{background:var(--error);color:#fff;text-decoration:none}.table-loading,.table-empty{text-align:center;padding:2rem;color:var(--text-secondary);font-size:.875rem}.project-desc{font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}.pagination{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:2rem}.pagination-btn{background:var(--bg);border:1px solid var(--border);border-radius:.5rem;padding:.5rem;cursor:pointer;color:var(--text-secondary);transition:all .2s}.pagination-btn:hover:not(:disabled){background:var(--bg-secondary);color:var(--text-primary)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-icon{width:18px;height:18px}.pagination-number{background:var(--bg);border:1px solid var(--border);border-radius:.5rem;padding:.5rem .75rem;cursor:pointer;color:var(--text-secondary);transition:all .2s;min-width:40px}.pagination-number:hover{background:var(--bg-secondary)}.pagination-number.active{background:var(--primary);color:#fff;border-color:var(--primary)}.pagination-ellipsis{color:var(--text-secondary);padding:0 .5rem}.workflow-main{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-secondary)}.workflow-header{background:var(--bg);border-bottom:1px solid var(--border);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.workflow-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);cursor:text;border-radius:.25rem;padding:.1rem .35rem;min-width:6rem;outline:none;transition:background .15s,box-shadow .15s}.workflow-title:hover{background:#ffffff0d}.workflow-title:focus{background:#ffffff12;box-shadow:0 0 0 2px var(--accent-color, #6366f1)}.workflow-title:empty:before{content:attr(data-placeholder);color:var(--text-secondary);pointer-events:none}.workflow-actions{display:flex;gap:.75rem;align-items:center}.undo-redo-group{display:flex;gap:.25rem;margin-right:.25rem;border-right:1px solid var(--border);padding-right:.75rem}.btn-undo-redo{display:inline-flex;align-items:center;gap:.3rem;padding:.4rem .75rem;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text-primary);font-size:.8rem;font-weight:500;cursor:pointer;transition:background .15s,opacity .15s;white-space:nowrap}.btn-undo-redo:hover:not(:disabled){background:var(--bg-secondary)}.btn-undo-redo:disabled{opacity:.35;cursor:not-allowed}.workflow-content{flex:1;min-height:0;display:flex;overflow:hidden}.resources-panel{flex-shrink:0;width:185px;background:var(--bg);border-right:1px solid var(--border);padding:1rem;overflow-y:auto;display:flex;flex-direction:column}.panel-title{font-size:1rem;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}.panel-subtitle{font-size:.875rem;color:var(--text-secondary);margin-bottom:1.5rem}.resource-search-wrap{position:relative;margin-bottom:.75rem}.resource-search-icon{position:absolute;left:8px;top:50%;transform:translateY(-50%);color:var(--text-secondary);pointer-events:none}.resource-search-input{width:100%;padding:.4rem .5rem .4rem 1.75rem;border:1px solid var(--border);border-radius:6px;font-size:.8rem;background:var(--bg);color:var(--text-primary);outline:none;transition:border-color .15s}.resource-search-input:focus{border-color:var(--primary)}.resource-search-input::placeholder{color:var(--text-secondary)}.resources-list{display:flex;flex-direction:column;gap:.75rem}.resource-category{margin-top:1rem;margin-bottom:.5rem}.resource-category:first-child{margin-top:0}.category-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin:0;padding:.5rem 0}.resource-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border:1px solid var(--border);border-radius:.5rem;cursor:grab;transition:all .2s;background:var(--bg)}.resource-item:hover{background:var(--bg-secondary);border-color:var(--primary)}.resource-item:active{cursor:grabbing}.resource-icon{width:24px;height:24px;color:var(--text-secondary)}.canvas-container{flex:1;min-width:0;position:relative}.canvas-viewport{position:relative;width:100%;height:100%;overflow:hidden;background:#f7f8fa;cursor:default;-webkit-user-select:none;user-select:none}.btn-delete-resource{display:none;align-items:center;justify-content:center;gap:.5rem;width:100%;margin-top:1.25rem;padding:.6rem 1rem;border:1.5px solid var(--error);border-radius:.5rem;background:transparent;color:var(--error);font-size:.8125rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.btn-delete-resource svg{width:.9rem;height:.9rem;flex-shrink:0}.btn-delete-resource:hover{background:var(--error);color:#fff}.workflow-canvas{position:absolute;width:3000px;height:2000px;transform-origin:0 0}.canvas-viewport.panning{cursor:grabbing!important}.canvas-viewport.space-pan{cursor:grab}.zoom-controls{position:absolute;bottom:1rem;right:1rem;display:flex;align-items:center;gap:.2rem;background:#fff;border:1px solid var(--border);border-radius:8px;padding:.3rem .4rem;box-shadow:var(--shadow);z-index:200}.zoom-btn{width:26px;height:26px;border:none;background:transparent;border-radius:4px;cursor:pointer;font-size:1rem;line-height:1;display:flex;align-items:center;justify-content:center;color:var(--text-primary);padding:0}.zoom-btn:hover{background:var(--bg-secondary)}.zoom-reset-btn{font-size:.85rem;width:auto;padding:0 .4rem;font-weight:500}.zoom-level{font-size:.75rem;color:var(--text-secondary);min-width:38px;text-align:center;font-variant-numeric:tabular-nums}.canvas-grid{position:absolute;top:0;left:0;width:100%;height:100%}.canvas-node{position:absolute;background:#fff;border:1px solid #e4e7ec;border-radius:14px;padding:14px 12px 10px;width:120px;text-align:center;cursor:move;box-shadow:0 1px 3px #0000000f,0 2px 8px #0000000a;transition:box-shadow .15s,border-color .15s,transform .1s}.canvas-node:hover{border-color:#c7d2fe;box-shadow:0 4px 16px #6366f124,0 1px 3px #00000012;transform:translateY(-1px)}.canvas-node.selected{border-color:#6366f1;box-shadow:0 0 0 2.5px #6366f133,0 4px 18px #6366f12e;transform:translateY(-1px)}.canvas-node.dragging{opacity:.6;cursor:grabbing;transform:scale(1.04)}.node-body{display:flex;flex-direction:column;align-items:center;gap:8px}.node-icon-wrap{width:52px;height:52px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#fff;overflow:hidden}.node-icon-wrap img{border-radius:8px;display:block;-webkit-user-select:none;user-select:none}.node-name{font-size:.68rem;font-weight:500;color:#374151;text-align:center;line-height:1.35;word-break:break-word;max-width:106px;display:block}.node-header,.node-type,.node-output{display:none}.connections-layer{position:absolute;top:0;left:0;width:100%;height:100%;overflow:visible;pointer-events:none}.connection-path{fill:none;stroke:#475569;stroke-width:1.5px;stroke-linejoin:round;marker-end:url(#arrow);pointer-events:visibleStroke;cursor:pointer;transition:stroke .1s,stroke-width .1s}.connection-path:hover{stroke:#1e293b;stroke-width:2px}.connection-selected{stroke:#f59e0b!important;stroke-width:2px!important;marker-end:url(#arrow-selected)!important}.connection-ghost{fill:none;stroke:#94a3b8;stroke-width:1.5px;stroke-dasharray:6 4;stroke-linejoin:round;pointer-events:none}.node-port{position:absolute;width:10px;height:10px;background:#fff;border:1.5px solid #94a3b8;border-radius:50%;opacity:0;transition:opacity .15s,transform .15s,border-color .15s,background .15s;z-index:10}.canvas-node:hover .node-port,.canvas-node.selected .node-port{opacity:1;border-color:#6366f1;box-shadow:0 0 0 2px #6366f133}.node-port-in{left:-6px;top:50%;transform:translateY(-50%);cursor:default}.node-port-out{right:-6px;top:50%;transform:translateY(-50%);cursor:crosshair}.node-port-out:hover{opacity:1!important;background:#6366f1;border-color:#4f46e5;transform:translateY(-50%) scale(1.4);box-shadow:0 0 0 3px #6366f140}.resource-item.dragging{opacity:.5}.empty-config{text-align:center;padding:2rem;color:var(--text-secondary)}.empty-config p{margin:0;font-size:.875rem}.node-connection-label{font-size:.7rem;color:var(--primary);margin-top:.5rem;font-style:italic}.config-panel{flex-shrink:0;width:240px;background:var(--bg);border-left:1px solid var(--border);padding:1rem;overflow-y:auto}.config-form{display:flex;flex-direction:column;gap:1rem}.config-form textarea.form-input{resize:vertical;min-height:80px;font-family:Courier New,monospace;font-size:.875rem}.code-viewer-main{flex:1;display:flex;flex-direction:column;background:var(--bg-secondary)}.code-viewer-header{background:var(--bg);border-bottom:1px solid var(--border);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.header-actions{display:flex;align-items:center;gap:1rem}.code-viewer-content{flex:1;display:flex;overflow:hidden}.code-editor-panel{flex:1;display:flex;flex-direction:column;background:var(--bg);border-right:1px solid var(--border)}.editor-header{padding:0;border-bottom:1px solid var(--border);background:var(--bg-secondary)}.file-tabs{display:flex;flex-wrap:wrap;gap:0;overflow-x:auto}.file-tab{padding:.625rem 1.125rem;font-family:Courier New,monospace;font-size:.8125rem;font-weight:500;color:var(--text-secondary);background:transparent;border:none;border-right:1px solid var(--border);border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;transition:color .15s,background .15s,border-color .15s}.file-tab:hover{color:var(--text-primary);background:var(--bg)}.file-tab.active{color:var(--primary);background:var(--bg);border-bottom-color:var(--primary);font-weight:600}.file-name{padding:.625rem 1.125rem;display:inline-block;font-family:Courier New,monospace;font-size:.875rem;color:var(--text-primary);font-weight:600}.btn-ai{background:linear-gradient(135deg,#6d28d9,#7c3aed);color:#fff;border:none;font-size:.8rem;font-weight:600;padding:.4rem .85rem;border-radius:.375rem;cursor:pointer;transition:opacity .15s,transform .1s;white-space:nowrap}.btn-ai:hover{opacity:.9;transform:translateY(-1px)}.btn-ai:active{transform:translateY(0)}.ai-prompt-wrap{padding:0 1.5rem .75rem;display:flex;flex-direction:column;gap:.75rem}.ai-prompt-input{width:100%;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:.5rem;color:var(--text);font-size:.9rem;line-height:1.6;padding:.75rem 1rem;resize:vertical;font-family:inherit;transition:border-color .15s;box-sizing:border-box}.ai-prompt-input:focus{outline:none;border-color:var(--primary)}.ai-prompt-input::placeholder{color:var(--text-muted, var(--text-secondary))}.ai-examples{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.ai-examples-label{font-size:.75rem;color:var(--text-secondary);flex-shrink:0}.ai-example-chip{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:1rem;padding:.25rem .65rem;font-size:.75rem;color:var(--primary);cursor:pointer;transition:background .15s,border-color .15s}.ai-example-chip:hover{background:#7c3aed1a;border-color:var(--primary)}.ai-modal-footer{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border);background:var(--bg-secondary);border-radius:0 0 .75rem .75rem}.ai-status{flex:1;font-size:.8rem;color:var(--text-secondary);display:flex;align-items:center;gap:.4rem}.modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-box{background:var(--bg);border-radius:12px;box-shadow:var(--shadow-lg);width:900px;max-width:95vw;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem .75rem;border-bottom:1px solid var(--border)}.modal-title{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.modal-close{background:none;border:none;font-size:1rem;cursor:pointer;color:var(--text-secondary);padding:.25rem;border-radius:4px;line-height:1}.modal-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.modal-subtitle{padding:.6rem 1.5rem .25rem;font-size:.82rem;color:var(--text-secondary)}.templates-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.85rem;padding:1rem 1.5rem 1.5rem;overflow-y:auto}@media(max-width:700px){.templates-grid{grid-template-columns:1fr 1fr}}.template-card{border:1px solid var(--border);border-radius:10px;padding:1.1rem 1.1rem .9rem;display:flex;flex-direction:column;gap:.5rem;transition:border-color .15s,box-shadow .15s;background:var(--bg)}.template-card:hover{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb14}.template-name{font-size:.95rem;font-weight:600;color:var(--text-primary)}.template-desc{font-size:.8rem;color:var(--text-secondary);line-height:1.5;flex:1}.template-tags{display:flex;flex-wrap:wrap;gap:.3rem}.template-tag{font-size:.7rem;padding:.15rem .5rem;border-radius:99px;background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border)}.template-use-btn{margin-top:.25rem;width:100%;padding:.45rem;font-size:.82rem}.cost-empty{font-size:.8rem;color:var(--text-secondary);padding:.75rem 0;text-align:center}.cost-skeleton{display:flex;flex-direction:column;gap:.5rem;padding:.5rem 0}.cost-skeleton-bar{height:.75rem;background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-tertiary) 50%,var(--bg-secondary) 75%);background-size:200% 100%;border-radius:.25rem;animation:skeleton-shimmer 1.4s infinite}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.cost-header-card{background:linear-gradient(135deg,#1e3a5f,#2563eb);border-radius:.5rem;padding:.875rem 1rem;margin-bottom:.75rem;color:#fff}.cost-header-label{font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;opacity:.8;margin-bottom:.3rem}.cost-header-amount{font-size:1.6rem;font-weight:700;line-height:1.1;margin-bottom:.3rem}.cost-header-amount.cost-header-free{color:#6ee7b7}.cost-header-high{font-size:1rem;font-weight:500;opacity:.75}.cost-header-sub{font-size:.7rem;opacity:.65}.cost-rows{display:flex;flex-direction:column;gap:.2rem;margin-bottom:.75rem}.cost-row{display:flex;align-items:center;gap:.5rem;padding:.4rem .5rem;border-radius:.375rem;cursor:default;transition:background .1s}.cost-row:hover{background:var(--bg-secondary)}.cost-row-icon{font-size:1rem;width:1.4rem;text-align:center;flex-shrink:0}.cost-row-info{display:flex;flex-direction:column;gap:.05rem;flex:1;min-width:0}.cost-row-name{font-size:.78rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cost-row-type{font-size:.65rem;color:var(--text-secondary);font-family:Courier New,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cost-badge{flex-shrink:0;font-size:.72rem;font-weight:600;padding:.15rem .45rem;border-radius:999px;white-space:nowrap}.cost-badge-free{background:#d1fae5;color:#065f46}.cost-badge-paid{background:#eff6ff;color:#1e40af;border:1px solid #bfdbfe}.cost-per-mo{font-weight:400;opacity:.75}.cost-footer{display:flex;gap:.35rem;align-items:flex-start;font-size:.67rem;color:var(--text-secondary);line-height:1.45;border-top:1px solid var(--border);padding-top:.6rem}.validate-spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.validator-badge{display:inline-block;border-radius:.25rem;padding:.1rem .5rem;font-size:.7rem;font-weight:600;margin-left:.5rem;vertical-align:middle}.validator-badge-real{background:#10b98126;color:var(--success);border:1px solid rgba(16,185,129,.3)}.validator-badge-static{background:#f59e0b1f;color:var(--warning);border:1px solid rgba(245,158,11,.3)}.resource-badge{display:inline-block;background:var(--bg-secondary);border:1px solid var(--border);border-radius:.25rem;padding:0 .375rem;font-family:Courier New,monospace;font-size:.75rem;color:var(--primary);margin-left:.25rem}.code-editor{flex:1;overflow:hidden;background:#0f172a;position:relative;min-height:0}.editor-footer{padding:1rem 1.5rem;border-top:1px solid var(--border);background:var(--bg-secondary);display:flex;justify-content:space-between;align-items:center}.validation-summary{font-size:.875rem;color:var(--text-secondary)}.validation-status{margin-left:.5rem;color:var(--success);font-weight:500}.validation-panel{width:400px;background:var(--bg);padding:1.5rem;overflow-y:auto}.validation-list{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.validation-item{display:flex;gap:1rem;padding:1rem;border-radius:.5rem;border:1px solid var(--border)}.validation-item.success{background:#f0fdf4;border-color:var(--success)}.validation-item.error{background:#fef2f2;border-color:var(--error)}.validation-item.warning{background:#fffbeb;border-color:var(--warning)}.validation-icon{width:24px;height:24px;flex-shrink:0}.validation-icon.success{color:var(--success)}.validation-icon.error{color:var(--error)}.validation-icon.warning{color:var(--warning)}.validation-content{flex:1}.validation-title{font-weight:600;margin-bottom:.25rem;color:var(--text-primary)}.validation-message{font-size:.875rem;color:var(--text-secondary)}.deployment-main{flex:1;display:flex;flex-direction:column;background:var(--bg-secondary)}.deployment-header{background:var(--bg);border-bottom:1px solid var(--border);padding:1.5rem 2rem;display:flex;justify-content:space-between;align-items:flex-start}.deployment-info{margin-top:.5rem}.deployment-name{font-size:1.25rem;font-weight:600;margin-bottom:.75rem;color:var(--text-primary)}.deployment-meta{display:flex;align-items:center;gap:1rem}.status-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .75rem;border-radius:.375rem;font-size:.875rem;font-weight:500}.status-badge.warning{background:#fffbeb;color:var(--warning)}.status-badge.success{background:#f0fdf4;color:var(--success)}.status-badge.error{background:#fef2f2;color:var(--error)}.status-dot{width:8px;height:8px;border-radius:50%;background:currentColor;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.deployment-time{font-size:.875rem;color:var(--text-secondary)}.deployment-actions{display:flex;gap:.75rem}.deployment-content{flex:1;display:flex;overflow:hidden}.deployment-logs-panel{flex:1;display:flex;flex-direction:column;background:#1e293b;border-right:1px solid var(--border)}.logs-header{padding:1rem 1.5rem;background:#0f172a;color:#e2e8f0;font-weight:600;border-bottom:1px solid #334155}.logs-container{flex:1;overflow-y:auto;padding:1.5rem;font-family:Courier New,monospace;font-size:.875rem;line-height:1.8}.log-entry{margin-bottom:.75rem;color:#cbd5e1}.log-entry.error{color:#fca5a5}.log-entry.warning{color:#fcd34d}.log-time{color:#94a3b8;margin-right:.5rem}.log-message{color:inherit}.deployment-summary-panel{width:360px;background:var(--bg);padding:1.5rem;overflow-y:auto}.summary-content{display:flex;flex-direction:column;gap:1rem;margin-top:1rem;margin-bottom:1.5rem}.summary-item{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:1px solid var(--border)}.summary-item:last-child{border-bottom:none}.summary-label{font-size:.875rem;color:var(--text-secondary)}.summary-value{font-weight:600;color:var(--text-primary)}.summary-value.success{color:var(--success)}.summary-value.error{color:var(--error)}.log-entry.success .log-message{color:#86efac}.log-info{color:#94a3b8;font-style:italic}.deployment-files{margin-top:1.5rem;border-top:1px solid var(--border);padding-top:1rem}.deployment-files-title{font-size:.8125rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.75rem}.deployment-files-list{list-style:none;display:flex;flex-direction:column;gap:.4rem}.deployment-file-item{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;font-family:Courier New,monospace;color:var(--text-primary)}.deployment-file-item svg{width:.9rem;height:.9rem;color:var(--text-secondary);flex-shrink:0}@media(max-width:1024px){.sidebar{width:220px}.workflow-content{flex-direction:column}.resources-panel{width:100%;max-height:200px}.config-panel{width:100%;max-height:300px}}@media(max-width:768px){.app-container{flex-direction:column}.sidebar{width:100%;max-height:auto}.top-bar{flex-direction:column;gap:1rem}.search-bar{max-width:100%}}.auth-method-selector{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2rem}.radio-card{position:relative;display:flex;cursor:pointer}.radio-card input[type=radio]{position:absolute;opacity:0}.radio-card-content{flex:1;display:flex;flex-direction:column;padding:1rem;background:var(--bg);border:2px solid var(--border);border-radius:.5rem;transition:all .2s ease}.radio-card input[type=radio]:checked+.radio-card-content{border-color:var(--primary);background:var(--bg-tertiary)}.radio-title{font-weight:600;color:var(--text-primary);font-size:1rem;display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.radio-desc{font-size:.75rem;color:var(--text-secondary)}.badge{background:var(--primary);color:#fff;padding:.1rem .25rem;border-radius:9999px;font-size:.5rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.instructions-box{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:.5rem;padding:1.25rem;margin-bottom:1.5rem}.instructions-box h4{margin-bottom:.75rem;color:var(--text-primary)}.instructions-box p{color:var(--text-secondary);font-size:.875rem;margin-bottom:1rem}.info-block{background:var(--bg);border-radius:.375rem;padding:1rem;border:1px solid var(--border)}.info-block p{margin-bottom:.5rem;color:var(--text-primary)}.info-block p:last-child{margin-bottom:0}.info-block strong{display:inline-block;width:200px;color:var(--text-secondary)}.code-span{font-family:monospace;background:var(--bg-secondary);padding:.125rem .375rem;border-radius:.25rem;color:var(--primary)}.margin-top-1rem{margin-top:1rem}.instructions-text{font-size:.875rem;color:var(--text-secondary);margin-bottom:1rem}.auth-section{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}#accessKeySection.active,#assumeRoleSection.active{display:block}.aws-connect-main{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:2.5rem 1.5rem;background:var(--bg-secondary);overflow-y:auto}.aws-connect-card{width:100%;max-width:520px;background:var(--bg);border:1px solid var(--border);border-radius:.75rem;box-shadow:var(--shadow-md);padding:2rem}.aws-connect-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.aws-connect-logo{width:48px;height:48px;background:#fff8f0;border:1px solid #fde8c4;border-radius:.625rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.aws-connect-logo svg{width:26px;height:26px}.aws-connect-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0}.aws-connect-subtitle{font-size:.8125rem;color:var(--text-secondary);margin:.2rem 0 0}.aws-status-banner{display:flex;align-items:center;gap:.625rem;padding:.625rem .875rem;border-radius:.5rem;font-size:.8125rem;font-weight:500;margin-bottom:1.5rem}.aws-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.aws-status-loading{background:var(--bg-tertiary);color:var(--text-secondary)}.aws-status-loading .aws-status-dot{background:var(--text-secondary)}.aws-status-connected{background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0}.aws-status-connected .aws-status-dot{background:var(--success)}.aws-status-disconnected{background:#fef9ec;color:#92400e;border:1px solid #fde68a}.aws-status-disconnected .aws-status-dot{background:var(--warning)}.aws-method-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;background:var(--bg-tertiary);padding:.25rem;border-radius:.5rem}.aws-method-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem .75rem;border:none;border-radius:.375rem;background:transparent;color:var(--text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s}.aws-method-tab svg{width:15px;height:15px;flex-shrink:0}.aws-method-tab:hover{color:var(--text-primary);background:var(--bg)}.aws-method-tab.active{background:var(--bg);color:var(--primary);box-shadow:var(--shadow-sm)}.aws-connect-form{display:flex;flex-direction:column;gap:0}.aws-connect-submit{margin-top:1.25rem}.aws-connect-feedback{padding:.625rem .875rem;border-radius:.5rem;font-size:.8125rem;font-weight:500;margin-top:.75rem}.aws-connect-feedback-error{background:#fef2f2;color:var(--error);border:1px solid #fecaca}.aws-connect-feedback-success{background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0}.aws-role-info{display:flex;gap:.625rem;padding:.75rem;background:#eff6ff;border:1px solid #bfdbfe;border-radius:.5rem;font-size:.8rem;color:#1d4ed8;margin-bottom:1rem}.aws-role-info svg{width:16px;height:16px;flex-shrink:0;margin-top:1px}.aws-role-info code{background:#dbeafe;padding:.1em .3em;border-radius:.2rem;font-size:.75rem}.form-hint-inline{font-size:.75rem;color:var(--text-secondary);font-weight:400;margin-left:.25rem}.deployments-list-main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-primary)}.deployments-list-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.deployments-list-content{flex:1;overflow-y:auto;padding:1.5rem}.deployments-loading,.deployments-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:4rem 2rem;color:var(--text-secondary);font-size:.95rem}.deployments-empty svg{opacity:.3}.deployments-table{width:100%;border-collapse:collapse;background:var(--bg-secondary);border-radius:.5rem;overflow:hidden;border:1px solid var(--border-color)}.deployments-table thead{background:var(--bg-tertiary, #1a1f2e)}.deployments-table th{padding:.75rem 1rem;text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border-bottom:1px solid var(--border-color)}.deployments-table td{padding:.875rem 1rem;font-size:.875rem;color:var(--text-primary);border-bottom:1px solid var(--border-color);vertical-align:middle}.deployments-table tr:last-child td{border-bottom:none}.deployments-table tr:hover td{background:#ffffff05}.depl-name{font-weight:500}.depl-time{color:var(--text-secondary);font-size:.8rem}.depl-actions{display:flex;gap:.5rem;align-items:center}.btn-sm{padding:.25rem .75rem;font-size:.8rem;border-radius:.25rem}.btn-danger{background:transparent;border:1px solid #ef4444;color:#ef4444;cursor:pointer;border-radius:.25rem;font-size:.8rem;padding:.25rem .75rem;transition:background .15s}.btn-danger:hover{background:#ef44441a}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.status-badge.status-not-deployed{background:var(--surface-100, #f8fafc);color:var(--text-secondary);border:1px solid var(--border)}.status-badge.status-succeeded{background:#f0fdf4;color:#16a34a}.status-badge.status-failed{background:#fef2f2;color:var(--error)}.status-badge.status-running,.status-badge.status-pending{background:#fffbeb;color:#d97706}.status-badge.destroyed{background:#64748b26;color:#94a3b8;border-color:#64748b4d}.aws-connection-banner{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1.5rem;font-size:.8rem;font-weight:500;border-bottom:1px solid transparent;transition:background .2s,border-color .2s}.aws-banner-connected{background:#22c55e1a;border-color:#22c55e4d;color:#000}.aws-banner-disconnected{background:#ef444414;border-color:#ef444440;color:#000}.aws-banner-left{display:flex;align-items:center;gap:.5rem}.aws-banner-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.aws-banner-connected .aws-banner-dot{background:#22c55e;box-shadow:0 0 6px #22c55eb3}.aws-banner-disconnected .aws-banner-dot{background:#ef4444;box-shadow:0 0 6px #ef444480}.aws-banner-right{color:inherit;opacity:.85}.aws-banner-link{color:#000;text-decoration:none;font-weight:600;border-bottom:1px solid rgba(0,0,0,.3)}.aws-banner-link:hover{color:#333;border-color:#333}.user-profile-link{display:block;text-decoration:none;color:inherit;border-radius:.5rem;transition:background .15s}.user-profile-link:hover{background:#ffffff0f}.profile-main{flex:1;display:flex;flex-direction:column;overflow-y:auto;background:var(--bg-secondary, #f8fafc)}.profile-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 2rem;background:var(--bg-primary, #fff);border-bottom:1px solid var(--border-color, #e2e8f0)}.profile-content{display:flex;flex-direction:column;gap:1.25rem;padding:1.5rem 2rem;max-width:720px}.profile-card{background:var(--bg-primary, #fff);border:1px solid var(--border-color, #e2e8f0);border-radius:.75rem;padding:1.5rem}.profile-card-title{font-size:.9375rem;font-weight:600;color:var(--text-primary, #1e293b);margin:0 0 1rem}.profile-card-desc{font-size:.8125rem;color:var(--text-secondary, #64748b);margin:-.5rem 0 1rem}.profile-card-header{display:flex;align-items:center;gap:1.25rem}.profile-avatar-large{width:4rem;height:4rem;border-radius:50%;background:var(--primary, #2563eb);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;flex-shrink:0}.profile-identity{display:flex;flex-direction:column;gap:.25rem}.profile-display-name{font-size:1.125rem;font-weight:600;color:var(--text-primary, #1e293b)}.profile-display-email{font-size:.875rem;color:var(--text-secondary, #64748b)}.profile-meta{display:flex;align-items:center;gap:.5rem;margin-top:.25rem}.profile-meta-item{font-size:.75rem;color:var(--text-tertiary, #94a3b8)}.profile-meta-sep{color:var(--text-tertiary, #94a3b8);font-size:.75rem}.profile-form{display:flex;flex-direction:column;gap:1rem}.profile-form-footer{display:flex;align-items:center;gap:.75rem;justify-content:flex-end;padding-top:.5rem}.profile-form-feedback{font-size:.8125rem;flex:1}.input-with-toggle{position:relative;display:flex;align-items:center}.input-with-toggle .form-input{flex:1;padding-right:2.5rem}.input-toggle-btn{position:absolute;right:.75rem;background:none;border:none;cursor:pointer;color:var(--text-secondary, #64748b);padding:0;display:flex;align-items:center}.input-toggle-btn:hover{color:var(--text-primary, #1e293b)}.form-label-hint{display:block;font-size:.75rem;font-weight:400;color:var(--text-secondary, #64748b);margin-top:.125rem}.profile-key-status{margin-top:.375rem;font-size:.8125rem}.profile-key-active{color:#16a34a}.profile-key-none{color:var(--text-secondary, #64748b)}.profile-aws-status{margin-top:.25rem}.profile-aws-connected{display:flex;align-items:center;gap:1rem}.profile-aws-dot{width:.625rem;height:.625rem;border-radius:50%;flex-shrink:0}.profile-aws-dot.connected{background:#22c55e}.profile-aws-dot.disconnected{background:#94a3b8}.profile-aws-info{flex:1;display:flex;flex-direction:column;gap:.2rem}.profile-aws-details{display:flex;align-items:center;flex-wrap:wrap;gap:.375rem;font-size:.8125rem;color:var(--text-secondary, #64748b)}.profile-aws-arn{font-family:monospace;font-size:.75rem;max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-loading{color:var(--text-secondary, #64748b);font-size:.875rem}.btn-sm{padding:.375rem .75rem;font-size:.8125rem}.btn-danger-outline{color:#ef4444;border-color:#ef4444;background:transparent}.btn-danger-outline:hover{background:#ef444414;border-color:#dc2626;color:#dc2626}.doc-picker-link{color:var(--primary, #2563eb);text-decoration:none;font-weight:500}.doc-picker-link:hover{text-decoration:underline}
