: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}.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-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}
