:root{--color-bg: #f5f5f5;--color-bg-card: #ffffff;--color-text: #1a1a1a;--color-text-secondary: #666666;--color-border: #e0e0e0;--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-success: #22c55e;--color-warning: #f59e0b;--color-error: #ef4444;--color-info: #3b82f6;--color-neutral: #9ca3af;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text);background-color:var(--color-bg);line-height:1.5}.auth-loading{display:flex;align-items:center;justify-content:center;min-height:100vh}.dashboard{min-height:100vh}.dashboard-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);background-color:var(--color-bg-card);border-bottom:1px solid var(--color-border)}.dashboard-header h1{font-size:var(--font-size-xl);font-weight:600}.header-controls{display:flex;align-items:center;gap:var(--spacing-lg)}.env-selector{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm);background-color:var(--color-bg-card);cursor:pointer}.user-info{display:flex;align-items:center;gap:var(--spacing-md)}.user-email{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.logout-btn{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-sm);background-color:transparent;cursor:pointer;font-size:var(--font-size-sm)}.logout-btn:hover{background-color:var(--color-bg)}.tab-bar{display:flex;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-lg);background-color:var(--color-bg-card);border-bottom:1px solid var(--color-border)}.tab{padding:var(--spacing-sm) var(--spacing-md);border:none;border-radius:var(--radius-sm);background-color:transparent;cursor:pointer;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);transition:background-color .15s,color .15s}.tab:hover{background-color:var(--color-bg)}.tab.active{background-color:var(--color-primary);color:#fff}.tab-content{padding:var(--spacing-lg)}.placeholder{color:var(--color-text-secondary);margin-top:var(--spacing-md)}.badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500}.badge-success{background-color:#dcfce7;color:#166534}.badge-warning{background-color:#fef3c7;color:#92400e}.badge-error{background-color:#fee2e2;color:#991b1b}.badge-info{background-color:#dbeafe;color:#1e40af}.badge-neutral{background-color:#f3f4f6;color:#4b5563}.dot{display:inline-block;width:8px;height:8px;border-radius:50%}.dot-healthy{background-color:var(--color-success)}.dot-degraded{background-color:var(--color-warning)}.dot-down{background-color:var(--color-error)}.dot-unknown{background-color:var(--color-neutral)}.mini-bar{display:flex;align-items:center;gap:var(--spacing-sm)}.mini-bar-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);min-width:40px}.mini-bar-track{flex:1;height:6px;background-color:var(--color-bg);border-radius:3px;overflow:hidden;min-width:60px}.mini-bar-fill{height:100%;border-radius:3px;transition:width .3s ease}.mini-bar-default{background-color:var(--color-primary)}.mini-bar-warning{background-color:var(--color-warning)}.mini-bar-error{background-color:var(--color-error)}.mini-bar-value{font-size:var(--font-size-sm);min-width:36px;text-align:right;white-space:nowrap}.mini-bar-suffix{color:var(--color-text-secondary);font-size:.75rem;margin-left:2px}.stage-pill{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.stage-name{font-weight:500}.stage-status{color:var(--color-text-secondary)}.stage-duration{color:var(--color-text-secondary);font-size:.75rem}.stage-completed{color:var(--color-text-secondary);font-size:.75rem;font-style:italic}.stage-passed{background-color:#dcfce7;border:1px solid #bbf7d0}.stage-failed{background-color:#fee2e2;border:1px solid #fecaca}.stage-running{background-color:#dbeafe;border:1px solid #bfdbfe}.stage-blocked{background-color:#f3f4f6;border:1px solid #e5e7eb}.stage-pending-gate{background-color:#fef3c7;border:1px solid #fde68a}.stage-not-implemented{background-color:#f3f4f6;border:1px solid #e5e7eb;opacity:.6}.stage-running .stage-name{animation:stage-running-pulse 1.4s ease-in-out infinite}@keyframes stage-running-pulse{0%,to{opacity:1}50%{opacity:.65}}.tab-lead{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:var(--spacing-sm);max-width:52rem}.fetched-at{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:var(--spacing-md) 0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.pipeline-header-row{display:flex;gap:var(--spacing-xl);align-items:flex-start;flex-wrap:wrap}.pipeline-header-info{flex:1;min-width:300px}.deploy-summary-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);flex:1;min-width:320px;max-width:50%}.deploy-summary-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-md);border-bottom:1px solid var(--color-border)}.deploy-summary-title{font-size:var(--font-size-base);font-weight:600;margin:0}.deploy-env-selector{display:flex;gap:2px;background:var(--color-bg);border-radius:var(--radius-sm);padding:2px}.deploy-env-btn{padding:var(--spacing-xs) var(--spacing-sm);border:none;border-radius:var(--radius-sm);background:transparent;font-size:.75rem;font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:background-color .15s,color .15s}.deploy-env-btn:hover{color:var(--color-text)}.deploy-env-btn-active{background:var(--color-bg-card);color:var(--color-text);box-shadow:var(--shadow-sm)}.deploy-summary-list{list-style:none;margin:0;padding:0;max-height:300px;overflow-y:auto}.deploy-summary-row{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-border)}.deploy-summary-row:last-child{border-bottom:none}.deploy-summary-row-other{background:var(--color-bg)}.deploy-summary-name{font-size:var(--font-size-sm);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.deploy-summary-time{font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap}.deploy-summary-time-na{color:var(--color-neutral)}.pipeline-section{margin-top:var(--spacing-xl)}.pipeline-section-title{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-md)}.pipeline-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.pipeline-microservice{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.pipeline-microservice-expanded{box-shadow:var(--shadow-md)}.pipeline-microservice-header{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-md)}.pipeline-expand-btn{border:none;background:transparent;cursor:pointer;padding:var(--spacing-xs);line-height:1;color:var(--color-text-secondary)}.pipeline-expand-btn:focus-visible{outline:2px solid var(--color-primary);border-radius:var(--radius-sm)}.pipeline-expand-icon{font-size:.65rem}.pipeline-microservice-title{flex:1;min-width:0}.pipeline-repo{display:block;font-weight:600;font-size:var(--font-size-base)}.pipeline-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.pipeline-branch{font-weight:500}.pipeline-commit{font-size:var(--font-size-sm);background:var(--color-bg);padding:2px 6px;border-radius:var(--radius-sm)}.pipeline-triggered{white-space:nowrap}.pipeline-run-link{font-size:var(--font-size-sm);color:var(--color-primary);text-decoration:none;white-space:nowrap;align-self:flex-start;padding-top:2px}.pipeline-run-link:hover{text-decoration:underline}.pipeline-summary{display:flex;flex-direction:column;align-items:flex-end;gap:var(--spacing-xs);margin-left:auto;margin-right:var(--spacing-md)}.mini-stage-row{display:flex;gap:2px}.mini-stage{display:flex;align-items:center;justify-content:center;width:32px;height:20px;border-radius:3px;font-size:.625rem;font-weight:600;text-transform:uppercase}.mini-stage-label{opacity:.9}.mini-stage-green{background-color:var(--color-success);color:#fff}.mini-stage-red{background-color:var(--color-error);color:#fff}.mini-stage-yellow{background-color:var(--color-warning);color:#fff}.mini-stage-blue{background-color:var(--color-info);color:#fff;animation:mini-stage-pulse 1.4s ease-in-out infinite}.mini-stage-gray{background-color:var(--color-neutral);color:#fff}@keyframes mini-stage-pulse{0%,to{opacity:1}50%{opacity:.6}}.pipeline-deploy-time{font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap}.pipeline-stages{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);padding:0 var(--spacing-md) var(--spacing-md) calc(28px + var(--spacing-md))}.pipeline-other-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.pipeline-other-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.pipeline-other-main{display:flex;align-items:center;gap:var(--spacing-md)}.pipeline-other-meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.table-wrap{overflow-x:auto;margin-top:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-card)}.data-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.data-table th,.data-table td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;border-bottom:1px solid var(--color-border);vertical-align:middle}.data-table th{background:var(--color-bg);font-weight:600;color:var(--color-text-secondary);white-space:nowrap}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--color-bg)}.td-strong{font-weight:600}.td-muted{color:var(--color-text-secondary);font-size:.8125rem;white-space:nowrap}.td-mini{min-width:140px}.cell-dot{display:inline-flex;align-items:center;gap:var(--spacing-xs)}.table-empty-row{color:var(--color-text-secondary);font-style:italic}.database-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-lg);margin-top:var(--spacing-md)}.info-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);box-shadow:var(--shadow-sm)}.info-card-title{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-md)}.info-card-badges{margin-bottom:var(--spacing-md)}.info-dl{display:flex;flex-direction:column;gap:var(--spacing-md)}.info-dl dt{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:500}.info-dl dd{margin-top:var(--spacing-xs);font-size:var(--font-size-base)}.database-metrics-bars{display:flex;flex-direction:column;gap:var(--spacing-md)}.metric-row{display:flex;justify-content:space-between;align-items:baseline;gap:var(--spacing-md);font-size:var(--font-size-sm)}.metric-label{color:var(--color-text-secondary)}.metric-value{font-weight:500;font-variant-numeric:tabular-nums}.alerts-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-sm);margin:var(--spacing-md) 0}.alerts-toolbar-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-right:var(--spacing-xs)}.filter-chip{padding:var(--spacing-xs) var(--spacing-md);border:1px solid var(--color-border);border-radius:999px;background:var(--color-bg-card);font-size:var(--font-size-sm);cursor:pointer;transition:background-color .15s,border-color .15s}.filter-chip:hover{background:var(--color-bg)}.filter-chip-active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.filter-chip:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.empty-state{margin-top:var(--spacing-lg);padding:var(--spacing-xl);text-align:center;color:var(--color-text-secondary);background:var(--color-bg-card);border:1px dashed var(--color-border);border-radius:var(--radius-md)}.alerts-list{list-style:none;display:flex;flex-direction:column;gap:var(--spacing-md);margin-top:var(--spacing-md)}.alert-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md) var(--spacing-lg);box-shadow:var(--shadow-sm)}.alert-card-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-sm)}.alert-service{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary)}.alert-name{font-size:var(--font-size-base);font-weight:600;margin-bottom:var(--spacing-xs)}.alert-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-sm)}.alert-reason{font-size:var(--font-size-sm);margin-bottom:var(--spacing-sm);word-break:break-word}.alert-updated{font-size:var(--font-size-sm);color:var(--color-text-secondary)}
