:root{--bg: #0f1117;--bg-surface: #1a1d27;--bg-hover: #242836;--border: #2e3348;--text: #e1e4ed;--text-muted: #8b8fa3;--primary: #6366f1;--primary-hover: #818cf8;--danger: #ef4444;--danger-hover: #f87171;--success: #22c55e;--warning: #f59e0b;--added: #22c55e;--deleted: #ef4444;--modified: #f59e0b;--radius: 8px;--sidebar-width: 220px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}html,body,#root{height:100%}body:has(.app){overflow:hidden}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-width);background:var(--bg-surface);border-right:1px solid var(--border);padding:1.5rem 0;position:fixed;top:0;left:0;bottom:0}.logo{padding:0 1.5rem 1.5rem;border-bottom:1px solid var(--border);margin-bottom:1rem;display:flex;align-items:center;gap:.6rem}.logo h2{color:var(--primary);font-size:1.25rem;letter-spacing:.5px}.sidebar ul{list-style:none}.sidebar li a{display:block;padding:.75rem 1.5rem;color:var(--text-muted);text-decoration:none;transition:all .15s}.sidebar li a:hover,.sidebar li a.active{color:var(--text);background:var(--bg-hover);border-right:3px solid var(--primary)}.sidebar{display:flex;flex-direction:column}.sidebar ul{flex:1}.sidebar-footer{padding:1rem 1.5rem;border-top:1px solid var(--border)}.sidebar-user{display:flex;flex-direction:column;margin-bottom:.5rem}.sidebar-user-name{font-size:.8rem;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-role{font-size:.7rem;color:var(--text-muted)}.sidebar-logout{width:100%}.content{margin-left:var(--sidebar-width);flex:1;padding:2rem;height:100vh;overflow-y:auto;display:flex;flex-direction:column}.content:has(.page-full){overflow:hidden}.page-full{display:flex;flex-direction:column;height:100%;overflow:hidden}.page-full h1{flex-shrink:0}.page h1{font-size:1.5rem;margin-bottom:1.5rem}.btn{padding:.5rem 1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-surface);color:var(--text);cursor:pointer;font-size:.875rem;transition:all .15s}.btn:hover{background:var(--bg-hover)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{background:transparent;border-color:var(--border)}.btn-danger{background:transparent;border-color:var(--danger);color:var(--danger)}.btn-danger:hover{background:var(--danger);color:#fff}.btn-sm{padding:.25rem .5rem;font-size:.75rem}.btn-lg{padding:.75rem 2rem;font-size:1rem}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.connect-buttons{display:flex;gap:.5rem}.alert{padding:.75rem 1rem;border-radius:var(--radius);margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center}.alert-success{background:#22c55e1a;border:1px solid var(--success);color:var(--success)}.alert-error{background:#ef44441a;border:1px solid var(--danger);color:var(--danger)}.alert-close{background:none;border:none;color:inherit;cursor:pointer;font-size:1.25rem}.org-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1rem}.org-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.org-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.org-card-header h3{font-size:1rem}.org-name-editable{cursor:pointer;display:inline-flex;align-items:center;gap:.35rem}.org-name-edit-icon{font-size:.75rem;color:var(--text-muted);opacity:0;transition:opacity .15s}.org-name-editable:hover .org-name-edit-icon{opacity:1}.org-name-input{font-size:1rem;font-weight:600;background:var(--bg);border:1px solid var(--primary);border-radius:4px;color:var(--text);padding:.2rem .5rem;width:100%;max-width:250px}.org-name-input:focus{outline:none}.badge{padding:.15rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase}.badge-prod{background:#6366f126;color:var(--primary)}.badge-sandbox{background:#f59e0b26;color:var(--warning)}.org-card-details p{font-size:.85rem;color:var(--text-muted);margin-bottom:.25rem}.org-card-details .label{color:var(--text);font-weight:500}.org-card-actions{display:flex;gap:.5rem;margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--border)}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-muted)}.empty-state h2{color:var(--text);margin-bottom:.5rem}.compare-setup{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.5rem}.conn-status{display:flex;align-items:center;gap:.4rem;font-size:.8rem;margin-top:.4rem;padding:.3rem .6rem;border-radius:4px}.conn-status-checking{color:var(--text-muted)}.conn-status-ok{color:#22c55e;background:#22c55e14}.conn-status-error{color:#ef4444;background:#ef444414}.conn-icon{font-weight:700}.conn-reconnect-btn{margin-left:.5rem;font-size:.75rem;padding:.15rem .5rem;color:var(--primary);border-color:var(--primary)}.org-selectors{display:flex;align-items:end;gap:1rem;margin-bottom:1.5rem}.org-selectors .form-group{flex:1}.arrow{font-size:1.5rem;color:var(--text-muted);padding-bottom:.5rem}.form-group label{display:block;font-size:.85rem;font-weight:500;margin-bottom:.35rem;color:var(--text-muted)}.form-group select{width:100%;padding:.5rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.875rem}.type-selector{margin-bottom:0}.type-selector-actions{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;flex-wrap:wrap}.muted{color:var(--text-muted);font-size:.8rem}.comparison-summary{display:flex;gap:1rem;margin-bottom:1.5rem}.summary-stat{flex:1;background:var(--bg-surface);border:2px solid var(--border);border-radius:var(--radius);padding:1rem;text-align:center;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none}.summary-stat:hover{border-color:var(--text-muted)}.summary-stat-active{border-color:var(--primary)!important;background:#6366f10f}.summary-stat-active .stat-label:after{content:" ✕";font-size:.65rem}.stat-number{display:block;font-size:2rem;font-weight:700}.stat-label{font-size:.8rem;color:var(--text-muted)}.summary-stat.added .stat-number{color:var(--added)}.summary-stat.deleted .stat-number{color:var(--deleted)}.summary-stat.modified .stat-number{color:var(--modified)}.col-status{width:90px}.status-badge{font-size:.7rem;font-weight:600;padding:.15rem .5rem;border-radius:3px;white-space:nowrap;text-transform:uppercase;letter-spacing:.03em}.status-added{color:#22c55e;background:#22c55e1a;border:1px solid rgba(34,197,94,.2)}.status-deleted{color:#ef4444;background:#ef44441a;border:1px solid rgba(239,68,68,.2)}.status-modified{color:#f59e0b;background:#f59e0b1a;border:1px solid rgba(245,158,11,.2)}.status-unchanged{color:var(--text-muted);background:#ffffff0a;border:1px solid var(--border)}.tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:1rem}.tab{padding:.5rem 1rem;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.875rem;border-bottom:2px solid transparent;transition:all .15s}.tab:hover{color:var(--text)}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.tab-actions{margin-bottom:.75rem}.component-group{margin-bottom:1rem}.component-type-header{font-size:.85rem;color:var(--primary);margin-bottom:.35rem;padding-bottom:.25rem;border-bottom:1px solid var(--border)}.component-item{display:flex;align-items:center;gap:.5rem;padding:.35rem .5rem;font-size:.85rem;border-radius:4px}.component-item:hover{background:var(--bg-hover)}.component-name{flex:1}.component-meta{font-size:.75rem}.deploy-bar{position:sticky;bottom:0;background:var(--bg-surface);border:1px solid var(--primary);border-radius:var(--radius);padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center;margin-top:1rem;gap:1rem}.deploy-bar-left{display:flex;flex-direction:column;gap:.5rem}.fls-toggle{display:flex;align-items:center;gap:.4rem;font-size:.825rem;cursor:pointer}.fls-toggle input[type=checkbox]{accent-color:var(--primary)}.fls-hint{color:var(--text-muted);font-size:.75rem}.loading{text-align:center;padding:3rem}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.deploy-table{width:100%;border-collapse:collapse}.deploy-table th,.deploy-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--border);font-size:.85rem}.deploy-table th{color:var(--text-muted);font-weight:500}.status-badge{padding:.15rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600}.status-success{background:#22c55e26;color:var(--success)}.status-error{background:#ef444426;color:var(--danger)}.status-pending{background:#f59e0b26;color:var(--warning)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;width:100%;max-width:440px}.modal h2{font-size:1.25rem;margin-bottom:.25rem}.modal-subtitle{color:var(--text-muted);font-size:.85rem;margin-bottom:1.5rem}.modal .form-group{margin-bottom:1rem}.modal .form-group input{width:100%;padding:.6rem .75rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.875rem}.modal .form-group input:focus{outline:none;border-color:var(--primary)}.form-hint{font-size:.75rem;color:var(--text-muted);margin-top:.35rem}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1.5rem}.compare-header-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:.75rem 1rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);flex-shrink:0}.compare-org-summary{display:flex;align-items:center;gap:.75rem;font-size:.95rem}.compare-org-summary .org-label{font-weight:600;color:var(--primary)}.compare-org-summary .arrow{color:var(--text-muted);padding:0}.compare-layout{display:flex;gap:1.5rem;flex:1;min-height:0;overflow:hidden}.compare-sidebar{width:260px;flex-shrink:0;overflow-y:auto;min-height:0}.compare-sidebar .type-selector{position:sticky;top:1rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.compare-main{flex:1;min-width:0;display:flex;flex-direction:column;min-height:0;overflow:hidden}.type-list{display:flex;flex-direction:column;gap:2px;max-height:calc(100vh - 200px);overflow-y:auto}.type-checkbox{display:flex;align-items:center;gap:.5rem;font-size:.825rem;cursor:pointer;padding:.35rem .5rem;border-radius:4px;transition:all .15s}.type-checkbox:hover{background:var(--bg-hover)}.type-checkbox .type-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.type-checkbox.type-loading .type-name{color:var(--text-muted)}.type-checkbox.type-done .type-name{color:var(--text)}.type-status{font-size:.7rem;flex-shrink:0}.type-status-pending{color:var(--text-muted)}.type-status-comparing{color:var(--primary)}.type-status-completed{color:var(--success);font-weight:600}.type-status-error{color:var(--danger);cursor:help}.spinner-sm{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.spinner-xs{display:inline-block;width:12px;height:12px;border:1.5px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.stream-progress{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;margin-bottom:1rem;background:#6366f114;border:1px solid rgba(99,102,241,.2);border-radius:var(--radius);font-size:.85rem;color:var(--primary-hover)}.component-table-wrap{overflow-x:auto}.component-table{width:100%;border-collapse:collapse;font-size:.85rem}.component-table thead th{text-align:left;padding:.5rem .75rem;color:var(--text-muted);font-weight:500;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--border);white-space:nowrap;position:relative;vertical-align:bottom}.component-table tbody tr{border-bottom:1px solid rgba(255,255,255,.04);transition:background .1s}.component-table tbody tr:hover{background:var(--bg-hover)}.component-table tbody tr.row-selected{background:#6366f114}.component-table td{padding:.4rem .75rem;vertical-align:middle}.component-table .col-check{width:32px;text-align:center}.component-table .col-type{width:160px}.component-table td.col-type{color:var(--text-muted)}.type-badge{font-size:.75rem;padding:.15rem .5rem;background:#6366f11a;border:1px solid rgba(99,102,241,.2);border-radius:3px;color:var(--primary);white-space:nowrap}.component-table .col-name{font-weight:500}.component-table .col-date{color:var(--text-muted);white-space:nowrap;width:160px}.component-table .col-by{color:var(--text-muted);white-space:nowrap;width:140px}.table-footer{padding:.5rem .75rem;font-size:.8rem;border-top:1px solid var(--border);display:flex;align-items:center}.th-inner{display:flex;align-items:center;gap:.35rem}.th-sortable{cursor:pointer;-webkit-user-select:none;user-select:none;display:inline-flex;align-items:center;gap:.25rem}.th-sortable:hover{color:var(--text)}.sort-icon{font-size:.7rem}.col-name-input{width:100px;padding:.2rem .4rem;font-size:.7rem;background:var(--bg);border:1px solid var(--border);border-radius:3px;color:var(--text)}.col-name-input:focus{outline:none;border-color:var(--primary);width:140px}.col-name-input::placeholder{color:var(--text-muted)}.col-filter-wrap{position:relative;display:inline-flex;align-items:center}.col-filter-btn{background:none;border:1px solid transparent;color:var(--text-muted);cursor:pointer;font-size:.65rem;padding:.1rem .3rem;border-radius:3px;line-height:1}.col-filter-btn:hover{background:var(--bg-hover);border-color:var(--border)}.col-filter-btn.col-filter-active{background:#6366f126;color:var(--primary);border-color:#6366f14d}.col-filter-dropdown{position:absolute;top:100%;left:0;z-index:100;min-width:160px;max-height:250px;overflow-y:auto;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 16px #0000004d;margin-top:2px}.col-filter-option{padding:.4rem .75rem;font-size:.8rem;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.col-filter-option:hover{background:var(--bg-hover)}.col-filter-option-selected{background:#6366f11f;color:var(--primary);font-weight:600}.row-clickable{cursor:pointer}.row-diff-active{border-left:3px solid var(--primary)!important;background:#6366f10f!important}.comparison-results,.comparison-results .tab-content{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.results-split{display:flex;flex-direction:column}.results-split-open{flex:1;min-height:0;overflow:hidden}.results-split-table{overflow-y:auto;flex:1;min-height:0}.results-split-open .results-split-table{overflow-y:auto;min-height:80px}.resize-handle{flex-shrink:0;height:8px;cursor:row-resize;display:flex;align-items:center;justify-content:center;background:var(--bg);border-top:1px solid var(--border);border-bottom:1px solid var(--border);transition:background .1s}.resize-handle:hover,.resize-handle:active{background:#6366f126}.resize-handle-bar{width:40px;height:3px;border-radius:2px;background:var(--text-muted);opacity:.4}.resize-handle:hover .resize-handle-bar{opacity:.8;background:var(--primary)}.results-split-diff{flex:1;min-height:100px;display:flex;flex-direction:column}.diff-panel{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--bg-surface);overflow:hidden}.diff-panel-header{display:flex;justify-content:space-between;align-items:center;padding:.6rem 1rem;background:#6366f10f;border-bottom:1px solid var(--border)}.diff-panel-title{display:flex;align-items:center;gap:.6rem;font-size:.85rem;min-width:0}.diff-type-badge{font-size:.7rem;padding:.1rem .4rem;background:#6366f11a;border:1px solid rgba(99,102,241,.2);border-radius:3px;color:var(--primary);flex-shrink:0}.diff-name{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.diff-stats{display:flex;gap:.5rem;font-size:.8rem;font-weight:600;flex-shrink:0}.diff-stat-added{color:#22c55e}.diff-stat-removed{color:#ef4444}.diff-panel-actions{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.diff-filename{font-size:.75rem}.diff-close{font-size:1rem;line-height:1;padding:.2rem .5rem}.diff-panel-labels{display:flex;align-items:center;gap:.5rem;padding:.4rem 1rem;font-size:.75rem;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--bg)}.diff-label-arrow{color:var(--text-muted)}.diff-panel-body{flex:1;min-height:0;overflow-y:auto}.diff-loading{display:flex;align-items:center;gap:.75rem;padding:2rem;justify-content:center;color:var(--text-muted);font-size:.85rem}.diff-error{padding:1.5rem;text-align:center;color:var(--danger);font-size:.85rem}.diff-binary-notice{padding:2rem;text-align:center;color:var(--text-muted);font-size:.85rem}.diff-content{overflow-x:auto}.diff-pre{margin:0;font-family:SF Mono,Fira Code,Consolas,Monaco,monospace;font-size:.8rem;line-height:1.5}.diff-line{display:flex;min-height:1.5em}.diff-line-added{background:#22c55e40;border-left:3px solid #22c55e}.diff-line-added .diff-text{color:#86efac}.diff-line-removed{background:#ef444433;border-left:3px solid #ef4444}.diff-line-removed .diff-text{color:#fca5a5}.diff-line-context{background:transparent;border-left:3px solid transparent}.diff-gutter{flex-shrink:0;width:40px;text-align:right;padding:0 .35rem;color:var(--text-muted);opacity:.5;-webkit-user-select:none;user-select:none;font-size:.7rem;line-height:1.5em;border-right:1px solid rgba(255,255,255,.06)}.diff-marker{flex-shrink:0;width:20px;text-align:center;color:var(--text-muted);-webkit-user-select:none;user-select:none;font-weight:700}.diff-line-added .diff-marker{color:#22c55e;font-size:.9rem}.diff-line-removed .diff-marker{color:#ef4444;font-size:.9rem}.diff-text{flex:1;white-space:pre;padding-right:1rem}.diff-separator{display:flex;align-items:center;justify-content:center;padding:.25rem 0;background:#6366f10f;border:1px dashed rgba(99,102,241,.15);border-left:3px solid transparent}.diff-separator-text{font-size:.7rem;color:var(--text-muted);font-style:italic}.diff-no-changes{display:flex;align-items:flex-start;gap:1rem;padding:1.5rem 2rem;background:#eab30814;border:1px solid rgba(234,179,8,.2);border-radius:var(--radius);margin:1rem}.diff-no-changes-icon{font-size:1.5rem;color:#eab308;flex-shrink:0}.diff-no-changes strong{display:block;margin-bottom:.35rem;color:#eab308}.diff-no-changes p{margin:0;font-size:.8rem;color:var(--text-muted);line-height:1.5}.diff-label-removed{color:#fca5a5;font-weight:500}.diff-label-added{color:#86efac;font-weight:500}.view-mode-toggle{display:inline-flex;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.view-mode-btn{background:transparent;border:none;color:var(--text-muted);padding:.25rem .75rem;font-size:.75rem;cursor:pointer;transition:all .15s}.view-mode-btn:hover{background:var(--bg-hover)}.view-mode-btn.view-mode-active{background:var(--primary);color:#fff}.flow-diagram-wrap{display:flex;flex-direction:column;height:100%;overflow:hidden}.flow-diagram-svg-wrap{flex:1;overflow:auto;padding:.5rem;min-height:200px}.flow-diagram-svg{display:block}.flow-empty{padding:2rem;text-align:center}.flow-node{transition:opacity .15s}.flow-node:hover{opacity:.85}.flow-node-name{fill:#e2e8f0;font-size:11.5px;font-weight:600;font-family:inherit}.flow-node-type{fill:#64748b;font-size:10px;font-weight:400;font-family:inherit}.flow-branch-label{fill:#94a3b8;font-size:10px;font-family:inherit}.flow-diagram-split .flow-legend{display:none}.flow-legend{display:flex;gap:1rem;padding:.5rem 1rem;border-top:1px solid var(--border);font-size:.75rem;flex-shrink:0}.flow-legend-item{display:flex;align-items:center;gap:.35rem;color:var(--text-muted)}.flow-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.flow-diagram-split{flex-direction:row!important}.flow-diagram-split .flow-diagram-svg-wrap{flex:1;min-width:0;border-right:1px solid var(--border)}.flow-node-code-panel{width:45%;min-width:300px;max-width:55%;display:flex;flex-direction:column;background:var(--bg);overflow:hidden}.flow-node-code-header{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-bottom:1px solid var(--border);font-size:.85rem;flex-shrink:0;background:var(--bg-surface)}.flow-node-code-header .btn{margin-left:auto}.flow-node-detail-type{font-size:.7rem;padding:.1rem .4rem;background:#6366f11a;border:1px solid rgba(99,102,241,.2);border-radius:3px;color:var(--primary);text-transform:uppercase}.flow-node-code-body{flex:1;overflow:auto;padding:0}.flow-node-code-body .diff-pre{margin:0;font-size:.78rem}.flow-prop-diff{overflow-x:auto}.flow-prop-table{width:100%;border-collapse:collapse;font-size:.78rem}.flow-prop-table thead th{text-align:left;padding:.3rem .5rem;color:var(--text-muted);font-weight:500;font-size:.7rem;text-transform:uppercase;border-bottom:1px solid var(--border)}.flow-prop-row{border-bottom:1px solid rgba(255,255,255,.04)}.flow-prop-row.flow-prop-added{background:#22c55e0f}.flow-prop-row.flow-prop-deleted{background:#ef44440f}.flow-prop-row.flow-prop-modified{background:#f59e0b0f}.flow-prop-key{padding:.3rem .5rem;font-weight:600;white-space:nowrap;color:var(--text-muted);width:140px}.flow-prop-val{padding:.3rem .5rem}.flow-prop-val pre{margin:0;white-space:pre-wrap;word-break:break-word;font-size:.75rem;max-height:120px;overflow-y:auto}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem;background:var(--bg)}.auth-card{width:100%;max-width:420px;background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:2.5rem}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h1{font-size:1.5rem;margin-top:1rem;margin-bottom:.35rem}.auth-form .form-group{margin-bottom:1rem}.auth-form input{width:100%;padding:.65rem .85rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.9rem}.auth-form input:focus{outline:none;border-color:var(--primary)}.auth-form input::placeholder{color:var(--text-muted)}.btn-full{width:100%}.login-section{margin-bottom:1.5rem}.login-section h3{font-size:.95rem;margin-bottom:.35rem}.sf-login-buttons{display:flex;flex-direction:column;gap:.5rem;margin-top:.75rem}.login-divider{display:flex;align-items:center;gap:1rem;margin:1.5rem 0;color:var(--text-muted);font-size:.8rem}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border)}.admin-tabs{display:flex;gap:0;margin-bottom:1.5rem;border-bottom:2px solid var(--border)}.admin-tab{background:none;border:none;color:var(--text-muted);padding:.75rem 1.25rem;font-size:.9rem;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}.admin-tab:hover{color:var(--text)}.admin-tab-active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.admin-add-user{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:1.5rem}.admin-add-user h3{font-size:.95rem;margin-bottom:.75rem}.admin-add-form{display:flex;gap:.5rem;align-items:flex-end}.admin-input{flex:1;padding:.5rem .75rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.85rem}.admin-input:focus{outline:none;border-color:var(--primary)}.admin-input::placeholder{color:var(--text-muted)}.admin-input-sm{flex:.6}.admin-users-table-wrap{overflow-x:auto}.admin-users-table{width:100%;border-collapse:collapse;font-size:.85rem}.admin-users-table thead th{text-align:left;padding:.6rem .75rem;color:var(--text-muted);font-weight:500;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--border)}.admin-users-table tbody tr{border-bottom:1px solid rgba(255,255,255,.04)}.admin-users-table tbody tr:hover{background:var(--bg-hover)}.admin-users-table td{padding:.6rem .75rem;vertical-align:middle}.admin-username{font-weight:500}.row-inactive{opacity:.5}.status-pill{font-size:.7rem;padding:.2rem .5rem;border-radius:12px;font-weight:600}.status-active{background:#22c55e26;color:var(--success)}.status-inactive{background:#ef444426;color:var(--danger)}.admin-actions{display:flex;gap:.35rem}.btn-danger{color:var(--danger);border-color:var(--danger)}.btn-danger:hover{background:#ef444426}.landing-page{min-height:100vh;background:var(--bg);padding:3rem 2rem;overflow-y:auto}.landing-hero{max-width:560px;text-align:center;margin:0 auto}.landing-badge{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.15em;padding:.25rem .75rem;border-radius:20px;background:#6366f126;color:var(--primary);border:1px solid rgba(99,102,241,.3);margin-bottom:1.5rem}.landing-logo{margin-bottom:1rem}.landing-title{font-size:2.5rem;font-weight:800;margin:0 0 .75rem;background:linear-gradient(135deg,#6366f1,#818cf8,#a5b4fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing-subtitle{font-size:1.1rem;color:var(--text-muted);line-height:1.6;margin:0 0 2.5rem}.landing-features{display:flex;flex-direction:column;gap:1.25rem;text-align:left;margin-bottom:2.5rem}.landing-feature{display:flex;gap:1rem;padding:1rem 1.25rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius)}.landing-feature-icon{font-size:1.3rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:#6366f11a;color:var(--primary);flex-shrink:0}.landing-feature strong{display:block;font-size:.9rem;margin-bottom:.2rem}.landing-feature p{margin:0;font-size:.8rem;color:var(--text-muted);line-height:1.5}.landing-cta{margin-bottom:2rem}.landing-cta .btn{min-width:260px}.landing-cta-hint{font-size:.75rem;color:var(--text-muted);margin-top:.5rem}.landing-waitlist{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;text-align:center;margin-bottom:2rem}.landing-waitlist h3{font-size:1.1rem;margin:0 0 .25rem}.waitlist-form{display:flex;flex-direction:column;gap:.6rem;margin-top:1rem}.waitlist-input{padding:.65rem .85rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.9rem;width:100%}.waitlist-input:focus{outline:none;border-color:var(--primary)}.waitlist-input::placeholder{color:var(--text-muted)}.waitlist-btn{width:100%}.waitlist-error{color:var(--danger);font-size:.8rem;margin-top:.5rem}.waitlist-success{display:flex;align-items:center;gap:1rem;text-align:left;padding:.5rem 0}.waitlist-success-icon{width:40px;height:40px;border-radius:50%;background:#22c55e26;color:var(--success);display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;flex-shrink:0}.waitlist-success strong{display:block;margin-bottom:.2rem}.waitlist-success p{margin:0;font-size:.85rem;color:var(--text-muted)}.landing-login-link{text-align:center;font-size:.85rem;color:var(--text-muted);margin-bottom:1.5rem}.btn-link{background:none;border:none;color:var(--primary);cursor:pointer;font-size:inherit;text-decoration:underline;padding:0}.btn-link:hover{color:var(--primary-hover)}.landing-footer{font-size:.75rem;color:var(--text-muted);text-align:center}.landing-footer-copyright{margin-bottom:.4rem}.landing-footer-links{display:flex;align-items:center;justify-content:center;gap:.5rem}.landing-footer-link{color:var(--text-muted);text-decoration:none}.landing-footer-link:hover{color:var(--primary);text-decoration:underline}.landing-sep{opacity:.3}@media(max-width:600px){.landing-page{padding:1.5rem 1rem;align-items:flex-start}.landing-hero{max-width:100%}.landing-logo svg{width:48px;height:48px}.landing-title{font-size:1.8rem}.landing-subtitle{font-size:.95rem;margin-bottom:1.5rem}.landing-features{gap:.75rem;margin-bottom:1.5rem}.landing-feature{padding:.75rem 1rem}.landing-feature-icon{width:30px;height:30px;font-size:1rem}.landing-feature strong{font-size:.85rem}.landing-feature p{font-size:.75rem}.landing-cta .btn{width:100%;min-width:unset}}.legal-page{min-height:100vh;background:var(--bg);padding:2rem;display:flex;justify-content:center}.legal-card{max-width:720px;width:100%;padding:2rem 0}.legal-header{margin-bottom:2rem}.legal-logo-link{display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;color:var(--primary);font-weight:700;font-size:1.1rem}.legal-logo-link:hover{opacity:.8}.legal-card h1{font-size:1.8rem;margin:0 0 .25rem}.legal-updated{color:var(--text-muted);font-size:.8rem;margin-bottom:2rem}.legal-card section{margin-bottom:1.75rem}.legal-card h2{font-size:1.05rem;margin:0 0 .5rem;color:var(--text)}.legal-card h3{font-size:.9rem;margin:.75rem 0 .35rem;color:var(--text)}.legal-card p{font-size:.88rem;color:var(--text-muted);line-height:1.7;margin:0 0 .5rem}.legal-card ul{padding-left:1.5rem;margin:.25rem 0 .5rem}.legal-card li{font-size:.88rem;color:var(--text-muted);line-height:1.7;margin-bottom:.25rem}.legal-card a{color:var(--primary)}.legal-card a:hover{text-decoration:underline}@media(max-width:600px){.legal-card{padding:1rem 0}.legal-card h1{font-size:1.4rem}}.deploy-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.deploy-progress-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}.deploy-progress-status{display:flex;align-items:center;gap:1.25rem;margin-bottom:1.5rem}.deploy-status-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;flex-shrink:0}.deploy-icon-success{background:#22c55e26;color:var(--success);border:2px solid var(--success)}.deploy-icon-failed{background:#ef444426;color:var(--danger);border:2px solid var(--danger)}.deploy-icon-progress{background:#6366f11a;border:2px solid var(--primary)}.deploy-status-label{font-size:1.1rem;font-weight:600;margin-bottom:.25rem}.deploy-sf-id,.deploy-timestamps{font-size:.8rem}.deploy-progress-bar-wrap{margin-bottom:1.5rem;display:flex;flex-direction:column;gap:.5rem}.deploy-progress-bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden}.deploy-progress-bar-fill{height:100%;background:var(--primary);border-radius:2px;animation:progressPulse 1.5s ease-in-out infinite}@keyframes progressPulse{0%{width:10%;opacity:.7}50%{width:70%;opacity:1}to{width:10%;opacity:.7}}.deploy-error-detail{margin-top:1rem;padding:1rem;background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius)}.deploy-error-detail h3{font-size:.9rem;color:var(--danger);margin-bottom:.5rem}.deploy-error-detail pre{font-size:.8rem;white-space:pre-wrap;word-break:break-word;color:var(--text-muted)}.deploy-failures,.deploy-successes{margin-top:1.5rem}.deploy-failures h3{font-size:.95rem;color:var(--danger);margin-bottom:.75rem}.deploy-successes h3{font-size:.95rem;color:var(--success);margin-bottom:.75rem}.deploy-detail-table{width:100%;border-collapse:collapse;font-size:.82rem}.deploy-detail-table thead th{text-align:left;padding:.5rem .75rem;color:var(--text-muted);font-weight:500;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border)}.deploy-detail-table tbody tr{border-bottom:1px solid rgba(255,255,255,.04)}.deploy-detail-table td{padding:.5rem .75rem}.deploy-problem{color:var(--danger);font-size:.8rem}.deploy-success-label{color:var(--success)}
