*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary: #00C28A;--color-primary-dark: #00a876;--color-bg: #F0F6F8;--color-surface: #ffffff;--color-text: #182023;--color-text-secondary: #597179;--color-border: #dddddd;--color-error: #D41840;--color-warning: #FFDF6C;--color-cyan: #00BCC2;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .15);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background-color:var(--color-bg);color:var(--color-text);line-height:1.5}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-md)}.header-left{display:flex;align-items:center;gap:.75rem;min-width:200px}.header-logo{height:40px;width:auto}.nav-menu-container{position:relative}.nav-menu-trigger{display:flex;align-items:center;gap:.5rem;background:transparent;border:none;color:#fff;font-size:1.25rem;font-weight:600;cursor:pointer;padding:.5rem .75rem;border-radius:var(--radius-sm);transition:background .2s}.nav-menu-trigger:hover{background:#ffffff26}.nav-arrow{font-size:.7rem;opacity:.8}.nav-dropdown{position:absolute;top:100%;left:0;margin-top:.5rem;background:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:200px;overflow:hidden;z-index:100}.nav-dropdown-item{display:block;width:100%;padding:.75rem 1rem;border:none;background:transparent;text-align:left;font-size:.9rem;color:var(--color-text);cursor:pointer;transition:background .15s}.nav-dropdown-item:hover{background:var(--color-bg)}.nav-dropdown-item.active{background:#00c28a1a;color:var(--color-primary);font-weight:500}.page-title{font-size:1.75rem;font-weight:600;margin:0;text-align:center;flex:1}.header-actions{display:flex;gap:.75rem;align-items:center}.last-updated{color:#fffc;font-size:.75rem;margin-right:.25rem}.refresh-btn{padding:.5rem 1rem;border:none;border-radius:var(--radius-sm);font-size:.875rem;cursor:pointer;transition:all .2s}.refresh-btn{background:#fff3;color:#fff}.refresh-btn:hover:not(:disabled){background:#ffffff4d}.refresh-btn:disabled{opacity:.6;cursor:not-allowed}.chat-toggle-btn{width:32px;height:32px;padding:0;border:2px solid rgba(255,255,255,.5);border-radius:50%;background:transparent;color:#fff;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.chat-toggle-btn svg{width:18px;height:18px}.chat-toggle-btn .chat-icon{width:28px;height:28px;border-radius:50%}.chat-toggle-btn:hover{background:#fff3;border-color:#fff}.help-btn{width:32px;height:32px;padding:0;border:2px solid rgba(255,255,255,.5);border-radius:50%;background:transparent;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.help-btn:hover{background:#fff3;border-color:#fff}.app-main{flex:1;padding:1.5rem 2rem;max-width:1400px;margin:0 auto;width:100%}.loading,.error{text-align:center;padding:3rem;font-size:1.1rem}.error{color:var(--color-error)}.deployment-table-container{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}.filters{padding:1rem 1.5rem;display:flex;gap:1.5rem;align-items:center;border-bottom:1px solid var(--color-border);flex-wrap:wrap}.filter-group{display:flex;align-items:center;gap:.5rem}.filter-group label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary)}.filter-group select,.filter-group input:not([type=checkbox]){padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.875rem;min-width:180px}.filter-group.checkbox-group label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:500;color:var(--color-text)}.filter-group.checkbox-group input[type=checkbox]{width:1rem;height:1rem;cursor:pointer;accent-color:var(--color-primary)}.filter-group input:focus,.filter-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #00c28a33}.filter-info{margin-left:auto;font-size:.875rem;color:var(--color-text-secondary)}.deployment-table{width:100%;border-collapse:collapse}.deployment-table th{background:#f0f6f8;padding:.875rem 1rem;text-align:left;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);border-bottom:2px solid var(--color-border)}.deployment-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.deployment-table th.sortable:hover{background:#e8f0f2}.deployment-table td{padding:.75rem 1rem;border-bottom:1px solid var(--color-border);font-size:.9rem}.deployment-table tbody tr{cursor:pointer;transition:filter .15s}.deployment-table tbody tr:hover{filter:brightness(.95)}.deployment-table .env-cell{font-weight:600}.deployment-table .version-cell{font-family:monospace;font-size:.85rem}.deployment-table .no-data{text-align:center;padding:2rem;color:var(--color-text-secondary)}.deployment-table .health-col{width:100px;text-align:center}.deployment-table .health-cell{text-align:center;font-weight:500;font-size:.85rem}.health-healthy{color:#00c28a}.health-unhealthy{color:#d41840}.health-degraded{color:#e67e22}.health-unknown{color:#888}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100}.modal-content{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:650px;width:90%;max-height:calc(80vh + 100px);overflow:auto;border:20px solid var(--color-border)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--color-border)}.modal-header h2{font-size:1.25rem;color:inherit}.modal-title{display:flex;align-items:center;gap:1rem}.history-link{background:none;border:none;color:inherit;cursor:pointer;padding:0;opacity:.85;display:flex;align-items:center;justify-content:center}.history-link svg{width:20px;height:20px}.history-link:hover{opacity:1}.modal-body{padding:1.5rem}.detail-row{display:flex;margin-bottom:.75rem}.detail-row .label{font-weight:500;color:var(--color-text-secondary);width:165px;flex-shrink:0;margin-right:1rem;white-space:nowrap}.detail-row .value{flex:1}.detail-row .value.previous,.detail-row .value.notes{font-size:.875rem;line-height:1.6}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:inherit;padding:.25rem;line-height:1;opacity:.7}.close-btn:hover{opacity:1}.modal-view-toggles{display:flex;gap:.5rem;margin-left:auto;margin-right:1rem}.modal-view-btn{background:none;border:none;color:inherit;cursor:pointer;padding:.25rem;opacity:.5;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:opacity .2s,background .2s}.modal-view-btn svg{width:20px;height:20px}.modal-view-btn:hover{opacity:.8;background:#0000001a}.modal-view-btn.active{opacity:1}.modal-settings{padding:1rem 0}.settings-placeholder{color:var(--color-text-secondary);font-style:italic;text-align:center;padding:2rem}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--color-border);display:flex;justify-content:flex-end}.modal-save-btn{background:var(--color-primary);color:#fff;border:none;padding:.5rem 1.5rem;border-radius:var(--radius-sm);font-size:.875rem;cursor:pointer;transition:background .2s}.modal-save-btn:hover{background:var(--color-primary-dark)}.codedeploy-value,.health-status-value{display:flex;align-items:center;gap:.5rem}.refresh-icon-btn{background:none;border:none;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);border-radius:var(--radius-sm);transition:color .2s,background .2s}.refresh-icon-btn:hover:not(:disabled){color:var(--color-primary);background:var(--color-bg)}.refresh-icon-btn:disabled{opacity:.5;cursor:not-allowed}.refresh-icon-btn svg{width:16px;height:16px}.spinner-small{width:14px;height:14px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.chatbot-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200}.chatbot-container{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:90%;max-width:500px;height:70vh;max-height:600px;display:flex;flex-direction:column}.chatbot-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border);background:var(--color-primary);color:#fff;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.chatbot-header h3{font-size:1rem;font-weight:600}.chatbot-header-actions{display:flex;gap:.5rem}.new-chat-btn{background:#fff3;border:none;color:#fff;padding:.375rem .75rem;border-radius:var(--radius-sm);font-size:.8rem;cursor:pointer}.new-chat-btn:hover{background:#ffffff4d}.chatbot-header .close-btn{color:#fff;font-size:1.25rem}.chatbot-messages{flex:1;overflow-y:auto;padding:1rem}.chatbot-welcome{text-align:center;padding:1rem;color:var(--color-text-secondary)}.chatbot-welcome p{margin-bottom:.75rem}.examples-title{font-weight:500;color:var(--color-text)}.example-questions{list-style:none;margin-top:.5rem}.example-questions li{background:#f0f6f8;padding:.5rem .75rem;border-radius:var(--radius-sm);margin-bottom:.5rem;font-size:.875rem;font-style:italic}.message{margin-bottom:1rem;max-width:85%}.message.user{margin-left:auto}.message.assistant{margin-right:auto}.message-content{padding:.75rem 1rem;border-radius:var(--radius-md);line-height:1.5}.message.user .message-content{background:var(--color-primary);color:#fff;border-bottom-right-radius:4px}.message.assistant .message-content{background:#f0f6f8;border-bottom-left-radius:4px}.message-time{font-size:.7rem;color:var(--color-text-secondary);margin-top:.25rem;text-align:right}.message.assistant .message-time{text-align:left}.message.loading .message-content{padding:1rem}.typing-indicator{display:flex;gap:4px}.typing-indicator span{width:8px;height:8px;background:#999;border-radius:50%;animation:typing 1s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,to{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}.chat-error{background:#d418401a;color:var(--color-error);padding:.75rem;border-radius:var(--radius-sm);font-size:.875rem;margin-bottom:1rem}.chatbot-input{display:flex;gap:.5rem;padding:1rem;border-top:1px solid var(--color-border)}.chatbot-input input{flex:1;padding:.75rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.9rem}.chatbot-input input:focus{outline:none;border-color:var(--color-primary)}.chatbot-input button{padding:.75rem 1.25rem;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s}.chatbot-input button:hover:not(:disabled){background:var(--color-primary-dark)}.chatbot-input button:disabled{opacity:.6;cursor:not-allowed}.help-view{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden;display:flex;flex-direction:column}.help-header{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;border-bottom:1px solid var(--color-border);background:#f0f6f8}.help-header h2{flex:1;font-size:1.25rem;margin:0}.help-content{padding:1.5rem;overflow-y:auto}.help-section{margin-bottom:1.5rem}.help-section:last-child{margin-bottom:0}.help-section h4{font-size:.95rem;font-weight:600;margin:0 0 .5rem;color:var(--color-text)}.help-description{font-size:.875rem;color:var(--color-text-secondary);margin:0 0 .75rem}.color-key{display:flex;flex-wrap:wrap;gap:.5rem}.color-swatch{padding:.5rem 1rem;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;border:1px solid var(--color-border)}.app-types-table{width:100%;border-collapse:collapse;font-size:.875rem}.app-types-table th,.app-types-table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--color-border)}.app-types-table th{background:#f0f6f8;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary)}.app-types-table tbody tr:hover{background:#f0f6f8}.help-section .no-data{color:var(--color-text-secondary);font-style:italic;font-size:.875rem}.help-loading{font-size:.875rem;color:var(--color-text-secondary);margin:0}.help-error{font-size:.875rem;color:var(--color-error);margin:0}.history-view{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}.history-header{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;border-bottom:1px solid var(--color-border);background:#f0f6f8}.history-header h2{flex:1;font-size:1.25rem;margin:0}.history-env{background:var(--color-primary);color:#fff;padding:.25rem .75rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500}.back-btn{background:none;border:1px solid var(--color-border);padding:.5rem 1rem;border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem;color:var(--color-text);transition:all .2s}.back-btn:hover{background:var(--color-bg);border-color:var(--color-primary);color:var(--color-primary)}.history-table-container{overflow-x:auto}.history-table{width:100%;border-collapse:collapse}.history-table th{background:#f0f6f8;padding:.875rem 1rem;text-align:left;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);border-bottom:2px solid var(--color-border)}.history-table td{padding:.75rem 1rem;border-bottom:1px solid var(--color-border);font-size:.9rem}.history-table tbody tr:hover{background:var(--color-bg)}.history-table .version-cell{font-family:monospace;font-size:.85rem}.history-table .notes-cell{max-width:300px;font-size:.85rem;line-height:1.4}.history-table .no-data{text-align:center;padding:2rem;color:var(--color-text-secondary)}.ecs-jobs-view{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden;display:flex;flex-direction:column;min-height:400px}.ecs-jobs-header{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;border-bottom:1px solid var(--color-border);background:#f0f6f8}.ecs-jobs-header h2{flex:1;font-size:1.25rem;margin:0}.ecs-jobs-content{flex:1;padding:1.5rem;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary)}.app-footer{text-align:center;padding:1rem;color:var(--color-text-secondary);font-size:.8rem;border-top:1px solid var(--color-border)}@media (max-width: 768px){.app-header{flex-direction:column;gap:.75rem;text-align:center;padding:1rem}.header-left{min-width:auto;justify-content:center}.page-title{font-size:1.25rem;order:-1}.nav-dropdown{left:50%;transform:translate(-50%)}.app-main{padding:1rem}.filters,.filter-group{flex-direction:column;align-items:stretch}.filter-group select,.filter-group input{width:100%}.filter-info{margin-left:0;text-align:center}.deployment-table th,.deployment-table td{padding:.5rem;font-size:.8rem}.chatbot-container{width:95%;height:80vh}.color-key{flex-direction:column}.color-swatch{text-align:center}}.status-link{background:none;border:none;color:#06c;cursor:pointer;text-decoration:underline;font:inherit;padding:0;text-align:left}.status-link:hover{color:#049}.status-detail-overlay{z-index:150}.status-detail-modal{max-width:900px;width:95%;max-height:85vh;display:flex;flex-direction:column}.status-detail-body{flex:1;overflow-y:auto;padding:1.5rem}.status-loading{display:flex;align-items:center;gap:.5rem;color:var(--color-text-secondary)}.status-error{background:#ffe6e6;color:#c00;padding:1rem;border-radius:var(--radius-sm);margin-bottom:1rem}.status-summary{background:#f5f5f5;padding:1rem;border-radius:var(--radius-sm);margin-bottom:1rem;line-height:1.5}.console-link{display:inline-block;background:#06c;color:#fff;padding:.5rem 1rem;border-radius:var(--radius-sm);text-decoration:none;margin-bottom:1rem;font-size:.875rem;font-weight:500}.console-link:hover{background:#049}.status-json{background:#1e1e1e;color:#d4d4d4;padding:1rem;border-radius:var(--radius-sm);overflow-x:auto;font-size:.8rem;white-space:pre-wrap;word-break:break-word;font-family:Monaco,Menlo,Ubuntu Mono,monospace;line-height:1.5;margin:0}@media (max-width: 768px){.status-detail-modal{width:98%;max-height:90vh}.status-detail-body{padding:1rem}.status-json{font-size:.75rem}}.healthcheck-settings{padding:0}.healthcheck-readonly{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.healthcheck-form-group{margin-bottom:1rem}.healthcheck-form-group label{display:block;font-weight:500;margin-bottom:.5rem;color:var(--color-text-secondary);font-size:.875rem}.healthcheck-form-group select,.healthcheck-form-group input{width:100%;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.875rem;box-sizing:border-box}.healthcheck-form-group select:focus,.healthcheck-form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #00c28a33}.healthcheck-kvp-container{margin-top:1rem}.healthcheck-kvp-container>label{display:block;font-weight:500;margin-bottom:.5rem;color:var(--color-text-secondary);font-size:.875rem}.healthcheck-kvp-row{display:flex;gap:.5rem;margin-bottom:.5rem;align-items:center}.healthcheck-kvp-row input{flex:1;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.875rem}.healthcheck-kvp-row input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #00c28a33}.healthcheck-add-btn,.healthcheck-remove-btn{padding:.25rem .5rem;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem}.healthcheck-add-btn{background:var(--color-bg);color:var(--color-primary);margin-top:.5rem;padding:.5rem 1rem;border:1px solid var(--color-border)}.healthcheck-add-btn:hover{background:#00c28a1a}.healthcheck-remove-btn{background:#d418401a;color:var(--color-error);width:28px;height:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.healthcheck-remove-btn:hover:not(:disabled){background:#d4184033}.healthcheck-remove-btn:disabled{opacity:.3;cursor:not-allowed}.healthcheck-none-message{color:var(--color-text-secondary);font-style:italic;font-size:.875rem;margin:1rem 0}.healthcheck-actions{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--color-border)}.healthcheck-save-btn{background:var(--color-primary);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:var(--radius-sm);cursor:pointer;font-weight:500;font-size:.875rem}.healthcheck-save-btn:hover:not(:disabled){background:#00a070}.healthcheck-save-btn:disabled{opacity:.6;cursor:not-allowed}.healthcheck-save-error{color:var(--color-error);font-size:.875rem;margin-top:.5rem}.healthcheck-save-success{color:var(--color-primary);font-size:.875rem;margin-top:.5rem}
