:root{--primary: #6366f1;--primary-light: #818cf8;--primary-dark: #4f46e5;--primary-bg: rgba(99, 102, 241, .08);--primary-bg-hover: rgba(99, 102, 241, .14);--accent: #06b6d4;--accent-light: #22d3ee;--accent-bg: rgba(6, 182, 212, .08);--brand-orange: #E8751A;--brand-orange-soft: #F09345;--brand-orange-deep: #C4622A;--brand-orange-bg: rgba(232, 117, 26, .1);--brand-orange-ring: rgba(232, 117, 26, .3);--success: #10b981;--success-light: #34d399;--success-bg: rgba(16, 185, 129, .1);--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .1);--danger: #ef4444;--danger-bg: rgba(239, 68, 68, .08);--info: #3b82f6;--info-bg: rgba(59, 130, 246, .08);--bg: #f8fafc;--surface: #ffffff;--surface-2: #f1f5f9;--surface-3: #e9eef5;--border: #e2e8f0;--border-light: #f1f5f9;--text: #0f172a;--text-secondary: #64748b;--text-muted: #94a3b8;--sidebar-bg: #0f172a;--sidebar-border: rgba(255, 255, 255, .06);--sidebar-text: #94a3b8;--sidebar-hover: rgba(255, 255, 255, .06);--sidebar-active: rgba(99, 102, 241, .15);--sidebar-active-text: #818cf8;--sidebar-width: 260px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .06);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .09);--shadow-card: 0 1px 3px rgba(0, 0, 0, .04), 0 4px 12px rgba(0, 0, 0, .03);--shadow-modal: 0 20px 60px rgba(0, 0, 0, .15);--ease: cubic-bezier(.4, 0, .2, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "SF Mono", "Fira Code", ui-monospace, Menlo, monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;font-family:var(--font)}html{font-size:15px}body{background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;background:none;border:none;color:inherit}input,select,textarea{font-family:inherit}.layout,.app-layout{display:flex;min-height:100vh;width:100%;background:var(--bg)}.main{margin-left:var(--sidebar-width);flex:1;min-height:100vh;display:flex;flex-direction:column}.content{padding:28px 32px 40px;flex:1}.content-inner{max-width:1400px}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow-y:auto;transition:transform .3s var(--ease)}.sidebar-brand{padding:14px 16px 12px 14px;display:flex;flex-direction:column;align-items:stretch;gap:2px;border-bottom:1px solid var(--sidebar-border);flex-shrink:0}.sidebar-brand+.nav-section{padding-top:8px}.sidebar-brand__link{display:block;text-decoration:none;opacity:.92;transition:opacity .15s var(--ease)}.sidebar-brand__link:hover{opacity:1}.brand-logo-img{width:100%;height:auto;display:block}.brand-version{font-size:10px;color:var(--sidebar-text);font-weight:500;text-align:right}.prototype-badge{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--primary);background:var(--sidebar-active);padding:2px 6px;border-radius:4px;border:1px solid rgba(99,102,241,.3);flex-shrink:0}.project-selector{margin:14px 14px 6px;padding:10px 14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);cursor:pointer;transition:background .2s;display:flex;align-items:center;gap:10px}.project-selector:hover{background:#ffffff14}.project-dot{width:8px;height:8px;background:var(--success);border-radius:50%;flex-shrink:0}.project-name{color:#e2e8f0;font-size:13px;font-weight:500;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-section{padding:14px 10px 4px}.nav-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.3px;color:#94a3b873;padding:0 12px;margin-bottom:5px}.nav-item{display:flex;align-items:center;gap:11px;padding:9px 14px;border-radius:var(--radius-sm);color:var(--sidebar-text);font-size:13.5px;font-weight:500;transition:all .15s var(--ease);cursor:pointer;margin-bottom:1px;width:100%;text-align:left;border:none;background:transparent}.nav-item:hover{background:var(--sidebar-hover);color:#cbd5e1}.nav-item.active{background:var(--sidebar-active);color:var(--sidebar-active-text);font-weight:600}.nav-item svg{width:18px;height:18px;flex-shrink:0}.nav-badge{margin-left:auto;background:var(--primary);color:#fff;font-size:10.5px;font-weight:700;padding:2px 7px;border-radius:10px;min-width:20px;text-align:center}.sidebar-footer{margin-top:auto;padding:14px;border-top:1px solid var(--sidebar-border);flex-shrink:0}.user-card{width:100%;display:flex;align-items:center;gap:11px;padding:8px 10px;border-radius:var(--radius-sm);border:none;background:transparent;cursor:pointer;transition:background .15s;text-align:left}.user-card:hover{background:#ffffff0a}.user-card.is-open{background:#ffffff0f}.user-card .user-chevron{width:14px;height:14px;flex-shrink:0;color:var(--sidebar-text);transform:rotate(-90deg);transition:transform .15s}.user-card.is-open .user-chevron{transform:rotate(90deg)}.user-meta{display:flex;align-items:center;gap:6px;margin-top:2px;flex-wrap:wrap}.auth-source{font-size:10.5px;color:#94a3b8b3;font-weight:500}.user-menu{margin-top:6px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);overflow:hidden;animation:fadeUp .15s var(--ease)}.user-menu__item{width:100%;display:flex;align-items:center;gap:10px;padding:9px 12px;background:transparent;border:none;color:var(--sidebar-text);font-size:13px;font-weight:500;cursor:pointer;text-align:left;transition:all .12s}.user-menu__item:hover{background:#ffffff12;color:#f1f5f9}.user-menu__item svg{width:14px;height:14px;flex-shrink:0}.user-avatar{width:36px;height:36px;border-radius:50%;background:radial-gradient(circle at 30% 25%,rgba(255,255,255,.18) 0%,transparent 55%),linear-gradient(135deg,var(--brand-orange) 0%,var(--brand-orange-deep) 100%);border:2px solid var(--brand-orange-ring);box-shadow:0 0 0 3px #e8751a1a;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:12.5px;letter-spacing:.3px;flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{color:#e2e8f0;font-size:13px;font-weight:600}.role-tag{display:inline-block;font-size:10.5px;color:var(--sidebar-active-text);background:var(--sidebar-active);padding:1px 7px;border-radius:10px;font-weight:600;text-transform:capitalize;margin-top:1px}.topbar{position:sticky;top:0;background:#f8fafce0;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border);padding:0 32px;height:64px;display:flex;align-items:center;justify-content:space-between;z-index:50;flex-shrink:0}.topbar-left{display:flex;align-items:center;gap:14px}.topbar-right{display:flex;align-items:center;gap:6px}.page-title{font-size:20px;font-weight:700;letter-spacing:-.3px;color:var(--text)}.topbar-btn{width:40px;height:40px;border:none;background:transparent;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);position:relative;transition:all .15s}.topbar-btn:hover{background:var(--surface-2);color:var(--text)}.topbar-btn svg{width:18px;height:18px}.notif-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;background:var(--danger);border-radius:50%;border:2px solid var(--bg)}.notif-bell{position:relative}.notif-bell.is-active{background:var(--surface-2);color:var(--text)}.notif-badge{position:absolute;top:4px;right:4px;min-width:18px;height:18px;padding:0 5px;background:var(--danger);color:#fff;font-size:10.5px;font-weight:700;border-radius:9px;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg);pointer-events:none}.notif-panel-backdrop{position:fixed;inset:0;z-index:900;background:#0f172a2e;animation:backdropIn .18s var(--ease)}.notif-panel{position:fixed;top:0;right:0;bottom:0;width:380px;max-width:92vw;background:var(--surface);border-left:1px solid var(--border);box-shadow:-8px 0 30px #0f172a1a;z-index:950;display:flex;flex-direction:column;animation:panelIn .22s var(--ease)}@keyframes panelIn{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.notif-panel__head{display:flex;align-items:center;gap:10px;padding:16px 18px;border-bottom:1px solid var(--border)}.notif-panel__title{flex:1;font-size:15px;font-weight:700;color:var(--text)}.notif-panel__close{width:32px;height:32px;border-radius:var(--radius-sm)}.notif-panel__body{flex:1;overflow-y:auto;padding:6px 0}.notif-panel__empty{padding:36px 18px;text-align:center;color:var(--text-secondary)}.notif-panel__empty p{font-size:14px;font-weight:600;color:var(--text);margin-bottom:6px}.notif-panel__empty small{font-size:12px;color:var(--text-muted)}.notif-item{display:flex;gap:10px;padding:12px 18px;border-bottom:1px solid var(--border-light);transition:background .15s}.notif-item:hover{background:var(--surface-2)}.notif-item.is-unread{background:var(--primary-bg)}.notif-item.is-unread:hover{background:var(--primary-bg-hover)}.notif-item__dot{width:8px;height:8px;margin-top:7px;border-radius:50%;background:transparent;flex-shrink:0}.notif-item.is-unread .notif-item__dot{background:var(--primary)}.notif-item__body{flex:1;min-width:0}.notif-item__msg{font-size:13px;color:var(--text);line-height:1.45}.notif-item__age{font-size:11.5px;color:var(--text-muted);margin-top:3px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:16px}.page-header-left h2,.page-header-left h1{font-size:24px;font-weight:700;letter-spacing:-.4px;margin-bottom:4px;color:var(--text)}.page-header-left p{color:var(--text-secondary);font-size:14px}.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text);transition:all .2s var(--ease);white-space:nowrap;line-height:1}.btn svg{width:15px;height:15px;flex-shrink:0}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 1px 4px #6366f140}.btn-primary:hover:not(:disabled){background:var(--primary-dark);border-color:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.btn-outline{background:var(--surface);color:var(--text-secondary)}.btn-outline:hover:not(:disabled){background:var(--surface-2);color:var(--text);border-color:var(--text-muted)}.btn-accent{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-accent:hover:not(:disabled){filter:brightness(.92);transform:translateY(-1px)}.btn-success{background:var(--success);color:#fff;border-color:var(--success)}.btn-success:hover:not(:disabled){filter:brightness(.92)}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover:not(:disabled){filter:brightness(.92)}.btn-danger-outline{background:var(--surface);color:var(--text-secondary)}.btn-danger-outline:hover:not(:disabled){background:var(--danger-bg);color:var(--danger);border-color:var(--danger)}.btn-ghost{background:transparent;border-color:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--surface-2);color:var(--text)}.btn-sm{padding:6px 13px;font-size:12px}.btn-sm svg{width:13px;height:13px}.btn-lg{padding:12px 24px;font-size:14px}.btn-lg svg{width:17px;height:17px}.btn-block{width:100%;justify-content:center}.action-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 13px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);font-size:12.5px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .15s}.action-btn svg{width:13px;height:13px}.action-btn:hover:not(:disabled){border-color:var(--text-muted);color:var(--text);background:var(--surface-2)}.action-btn.danger:hover:not(:disabled){border-color:var(--danger);color:var(--danger);background:var(--danger-bg)}.action-btn.success:hover:not(:disabled){border-color:var(--success);color:var(--success);background:var(--success-bg)}.action-btn.primary:hover:not(:disabled){border-color:var(--primary);color:var(--primary);background:var(--primary-bg)}.action-btn.accent:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.action-btn:disabled{opacity:.55;cursor:not-allowed}.icon-btn{width:34px;height:34px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted);transition:all .15s;flex-shrink:0}.icon-btn:hover{background:var(--primary-bg);color:var(--primary);border-color:var(--primary-light)}.icon-btn svg{width:15px;height:15px}.quick-action-btn{display:flex;align-items:center;gap:12px;padding:12px 16px;border:1px dashed var(--border);border-radius:var(--radius-sm);background:transparent;cursor:pointer;font-size:13.5px;font-weight:500;color:var(--text);transition:all .15s var(--ease);width:100%;text-align:left}.quick-action-btn:hover{border-color:var(--primary);background:var(--primary-bg);color:var(--primary)}.quick-action-btn svg{width:18px;height:18px;color:var(--text-muted);transition:color .15s}.quick-action-btn:hover svg{color:var(--primary)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-card)}.card-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px}.card-title{font-size:15px;font-weight:700;letter-spacing:-.2px;color:var(--text)}.card-body{padding:0 24px 22px}.card-action{font-size:13px;color:var(--primary);font-weight:600;cursor:pointer;padding:4px 10px;border-radius:6px;transition:background .15s;background:none;border:none}.card-action:hover{background:var(--primary-bg)}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}.status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.status-badge.running{background:var(--success-bg);color:#059669}.status-badge.running .status-dot{background:var(--success)}.status-badge.provisioning{background:var(--info-bg);color:#2563eb}.status-badge.provisioning .status-dot{background:var(--info);animation:pulse-dot 1.4s ease-in-out infinite}.status-badge.starting,.status-badge.stopping{background:var(--info-bg);color:#2563eb}.status-badge.starting .status-dot,.status-badge.stopping .status-dot{background:var(--info);animation:pulse-dot 1.4s ease-in-out infinite}.status-badge.restoring{background:var(--accent-bg);color:#0891b2}.status-badge.restoring .status-dot{background:var(--accent);animation:pulse-dot 1.4s ease-in-out infinite}.status-badge.stopped{background:var(--surface-2);color:var(--text-secondary)}.status-badge.stopped .status-dot{background:var(--text-muted)}.status-badge.error{background:var(--danger-bg);color:#dc2626}.status-badge.error .status-dot{background:var(--danger)}.status-badge.frozen{background:var(--accent-bg);color:#0891b2}.status-badge.frozen .status-dot{background:var(--accent)}.status-badge.terminated,.status-badge.torn_down,.status-badge.torn-down{background:var(--surface-2);color:var(--text-muted)}.status-badge.terminated .status-dot,.status-badge.torn_down .status-dot,.status-badge.torn-down .status-dot{background:var(--border)}.status-badge.snapshotting{background:var(--warning-bg);color:#b45309}.status-badge.snapshotting .status-dot{background:var(--warning);animation:pulse-dot 1.4s ease-in-out infinite}.status-badge.published{background:var(--success-bg);color:#059669}.status-badge.published .status-dot{background:var(--success)}.status-badge.draft{background:var(--surface-2);color:var(--text-secondary)}.status-badge.draft .status-dot{background:var(--text-muted)}.status-badge.unpublished{background:var(--danger-bg);color:#dc2626}.status-badge.unpublished .status-dot{background:var(--danger)}.tag{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:6px;font-size:12px;font-weight:500}.tag svg{width:12px;height:12px}.tag.primary{background:var(--primary-bg);color:var(--primary)}.tag.k8s{background:#dbeafe;color:#2563eb}.tag.vm{background:#fce7f3;color:#db2777}.tag.client{background:var(--surface-2);color:var(--text-secondary)}.tag.blueprint{background:var(--primary-bg);color:var(--primary)}.tag.success{background:var(--success-bg);color:#059669}.tag.warning{background:var(--warning-bg);color:#b45309}.tag.muted{background:var(--surface-2);color:var(--text-secondary)}.filter-chip{display:inline-flex;align-items:center;gap:6px;padding:7px 15px;border:1px solid var(--border);border-radius:20px;background:var(--surface);font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .15s}.filter-chip:hover{border-color:var(--primary-light);color:var(--primary);background:var(--primary-bg)}.filter-chip.active{border-color:var(--primary);color:var(--primary);background:var(--primary-bg)}.filter-chip svg{width:14px;height:14px}.form-group{margin-bottom:18px}.form-row{display:flex;align-items:center;gap:12px}.form-label{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:6px}.form-hint{font-size:11.5px;color:var(--text-muted);margin-top:4px}.form-error{font-size:11.5px;color:var(--danger);margin-top:4px}.form-input,.form-select,.form-textarea,.form-control{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13.5px;color:var(--text);background:var(--surface);outline:none;transition:all .2s}.form-input:focus,.form-select:focus,.form-textarea:focus,.form-control:focus{border-color:var(--primary-light);box-shadow:0 0 0 3px var(--primary-bg)}.form-input::placeholder,.form-textarea::placeholder,.form-control::placeholder{color:var(--text-muted)}.search-wrap{position:relative;flex:1;min-width:220px}.search-wrap svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--text-muted);pointer-events:none}.search-wrap input{padding-left:42px}.toggle-wrap{display:flex;align-items:center;gap:12px}.toggle{width:44px;height:24px;background:var(--border);border-radius:12px;position:relative;cursor:pointer;transition:background .2s;flex-shrink:0;border:none}.toggle:after{content:"";position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;top:3px;left:3px;transition:transform .2s;box-shadow:0 1px 3px #0003}.toggle.on{background:var(--primary)}.toggle.on:after{transform:translate(20px)}.toggle-label{font-size:13.5px;font-weight:500;color:var(--text)}.data-table{width:100%;border-collapse:collapse}.data-table thead th{text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);padding:0 20px 12px;border-bottom:1px solid var(--border);white-space:nowrap}.data-table tbody tr{transition:background .12s}.data-table tbody tr:hover{background:var(--surface-2)}.data-table td{padding:14px 20px;font-size:13.5px;border-bottom:1px solid var(--border-light);color:var(--text)}.data-table tbody tr:last-child td{border-bottom:none}.modal-backdrop{position:fixed;inset:0;background:#0f172a8c;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;animation:backdropIn .2s var(--ease)}.confirm-backdrop{z-index:1100}.confirm-modal{max-width:440px;padding:22px 24px}.confirm-modal__head{display:flex;gap:14px;align-items:flex-start;margin-bottom:18px}.confirm-modal__icon{width:28px;height:28px;flex-shrink:0;margin-top:2px}.confirm-modal__icon[data-tone=danger]{color:var(--danger)}.confirm-modal__icon[data-tone=primary]{color:var(--primary)}.confirm-modal__icon[data-tone=warning]{color:var(--warning)}.confirm-modal__body{flex:1;min-width:0}.confirm-modal__title{font-size:16px;font-weight:700;color:var(--text);letter-spacing:-.2px;margin-bottom:4px}.confirm-modal__msg{font-size:13.5px;color:var(--text-secondary);line-height:1.5}.confirm-modal__actions{display:flex;justify-content:flex-end;gap:8px;padding-top:14px;border-top:1px solid var(--border)}.modal,.modal-box{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-modal);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;animation:modalIn .25s var(--ease-spring)}.modal-lg{max-width:720px}.modal-sm{max-width:420px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:22px 24px 16px;border-bottom:1px solid var(--border)}.modal-title{font-size:17px;font-weight:700;letter-spacing:-.3px;color:var(--text)}.modal-close{width:34px;height:34px;border:none;background:transparent;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all .15s}.modal-close:hover{background:var(--surface-2);color:var(--text)}.modal-close svg{width:16px;height:16px}.modal-body{padding:22px 24px}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:16px 24px 20px;border-top:1px solid var(--border)}.tabs{display:flex;border-bottom:2px solid var(--border);margin-bottom:22px}.tab{display:flex;align-items:center;gap:8px;padding:12px 18px;font-size:13.5px;font-weight:500;color:var(--text-secondary);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;background:none;border-top:none;border-left:none;border-right:none}.tab:hover{color:var(--text)}.tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.tab svg{width:16px;height:16px}.tab-count{background:var(--surface-2);color:var(--text-secondary);font-size:11px;font-weight:700;padding:2px 7px;border-radius:10px}.tab.active .tab-count{background:var(--primary-bg);color:var(--primary)}.tab-panel{display:none}.tab-panel.active{display:block}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:26px}.stat-card{background:var(--surface);border-radius:var(--radius-md);padding:22px 24px;border:1px solid var(--border);box-shadow:var(--shadow-card);transition:all .25s var(--ease);cursor:pointer;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;border-radius:3px 3px 0 0;opacity:0;transition:opacity .25s}.stat-card:hover{border-color:transparent;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.stat-card:hover:before{opacity:1}.stat-card:nth-child(1):before{background:linear-gradient(90deg,var(--primary),var(--primary-light))}.stat-card:nth-child(2):before{background:linear-gradient(90deg,var(--accent),var(--accent-light))}.stat-card:nth-child(3):before{background:linear-gradient(90deg,var(--success),var(--success-light))}.stat-card:nth-child(4):before{background:linear-gradient(90deg,var(--warning),#fbbf24)}.stat-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.stat-icon{width:44px;height:44px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.stat-icon svg{width:20px;height:20px}.stat-icon.purple{background:var(--primary-bg);color:var(--primary)}.stat-icon.cyan{background:var(--accent-bg);color:var(--accent)}.stat-icon.green{background:var(--success-bg);color:var(--success)}.stat-icon.amber{background:var(--warning-bg);color:var(--warning)}.stat-trend{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:600;padding:3px 8px;border-radius:20px}.stat-trend.up{background:var(--success-bg);color:var(--success)}.stat-trend.down{background:var(--danger-bg);color:var(--danger)}.stat-trend svg{width:13px;height:13px}.stat-value{font-size:30px;font-weight:800;letter-spacing:-1px;line-height:1;margin-bottom:4px;color:var(--text)}.stat-label{font-size:13px;color:var(--text-secondary);font-weight:500}.env-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:16px}.env-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);overflow:hidden;transition:all .25s var(--ease)}.env-card:hover{border-color:transparent;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.env-card-top{height:4px}.env-card-top.running{background:linear-gradient(90deg,var(--success),var(--success-light))}.env-card-top.provisioning,.env-card-top.starting,.env-card-top.stopping{background:linear-gradient(90deg,var(--info),#60a5fa);animation:shimmer 2s ease-in-out infinite}.env-card-top.stopped{background:var(--border)}.env-card-top.error{background:linear-gradient(90deg,var(--danger),#f87171)}.env-card-top.frozen{background:linear-gradient(90deg,var(--accent),var(--primary-light))}.env-card-top.snapshotting,.env-card-top.restoring{background:linear-gradient(90deg,var(--warning),#fbbf24);animation:shimmer 2s ease-in-out infinite}.env-card-top.terminated,.env-card-top.torn_down,.env-card-top.torn-down{background:var(--surface-3)}.env-card-body{padding:18px 20px}.env-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px;gap:12px}.env-card-info{display:flex;align-items:center;gap:13px;flex:1;min-width:0}.env-type-icon{width:42px;height:42px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.env-type-icon svg{width:20px;height:20px}.env-type-icon.k8s{background:#dbeafe;color:#3b82f6}.env-type-icon.vm{background:#fce7f3;color:#ec4899}.env-card-name{font-size:14.5px;font-weight:700;letter-spacing:-.2px;margin-bottom:2px;color:var(--text)}.env-card-id{font-size:11.5px;color:var(--text-muted);font-family:var(--font-mono)}.env-card-meta{display:flex;gap:14px;margin-bottom:14px;flex-wrap:wrap}.meta-item{display:flex;align-items:center;gap:5px;font-size:12.5px;color:var(--text-secondary)}.meta-item svg{width:13px;height:13px;color:var(--text-muted)}.env-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid var(--border-light);gap:8px}.env-card-actions{display:flex;gap:6px;flex-wrap:wrap}.env-card-ttl{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-muted);flex-shrink:0}.env-card-ttl svg{width:13px;height:13px}.ttl-warning{color:var(--warning)}.ttl-expired{color:var(--danger)}.bp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.bp-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);overflow:hidden;transition:all .25s var(--ease)}.bp-card:hover{border-color:transparent;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.bp-card-top{height:4px}.bp-card-top.published{background:linear-gradient(90deg,var(--success),var(--success-light))}.bp-card-top.draft{background:var(--border)}.bp-card-top.unpublished{background:var(--danger-bg)}.bp-card-body{padding:18px 20px}.bp-icon{width:42px;height:42px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.bp-icon.k8s{background:#dbeafe;color:#3b82f6}.bp-icon.vm{background:#fce7f3;color:#ec4899}.bp-icon svg{width:20px;height:20px}.bp-card-name{font-size:15px;font-weight:700;letter-spacing:-.2px;margin-bottom:2px;color:var(--text)}.bp-card-version{font-size:12px;color:var(--text-muted);font-family:var(--font-mono)}.endpoint-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;transition:all .15s}.endpoint-card:hover{border-color:var(--primary-light);box-shadow:var(--shadow-sm)}.endpoint-label{font-size:12px;color:var(--text-muted);font-weight:500;margin-bottom:3px;text-transform:uppercase;letter-spacing:.5px}.endpoint-value{font-family:var(--font-mono);font-size:13px;color:var(--text);word-break:break-all}.toast{position:fixed;top:20px;right:20px;background:var(--surface);color:var(--text);padding:8px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;line-height:1.3;box-shadow:var(--shadow-lg);border:1px solid var(--border);border-left:3px solid var(--success);display:inline-flex;align-items:center;gap:8px;z-index:300;animation:toastIn .3s var(--ease-spring);max-width:360px;width:max-content}.toast svg{width:14px;height:14px;color:var(--success);flex-shrink:0}.toast--error,.toast.toast--error{border-left-color:var(--danger)}.toast--error svg{color:var(--danger)}.toast--warning{border-left-color:var(--warning)}.toast--warning svg{color:var(--warning)}.toast--info{border-left-color:var(--info)}.toast--info svg{color:var(--info)}.alert{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:var(--radius-sm);font-size:13.5px;margin-bottom:16px}.alert svg{width:18px;height:18px;flex-shrink:0;margin-top:1px}.alert.info{background:var(--info-bg);color:#1d4ed8;border-left:3px solid var(--info)}.alert.warning{background:var(--warning-bg);color:#b45309;border-left:3px solid var(--warning)}.alert.success{background:var(--success-bg);color:#065f46;border-left:3px solid var(--success)}.alert.danger{background:var(--danger-bg);color:#991b1b;border-left:3px solid var(--danger)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;text-align:center}.empty-icon{width:64px;height:64px;background:var(--surface-2);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:16px}.empty-icon svg{width:28px;height:28px;color:var(--text-muted)}.empty-state h3{font-size:16px;font-weight:700;margin-bottom:6px;color:var(--text)}.empty-state p{font-size:13.5px;color:var(--text-secondary);margin-bottom:20px;max-width:340px}.settings-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);margin-bottom:20px;overflow:hidden}.settings-section-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border)}.settings-section-title{display:flex;align-items:center;gap:12px;font-size:15px;font-weight:700;color:var(--text)}.settings-section-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.settings-section-icon svg{width:18px;height:18px}.settings-section-icon.purple{background:var(--primary-bg);color:var(--primary)}.settings-section-icon.cyan{background:var(--accent-bg);color:var(--accent)}.settings-section-icon.green{background:var(--success-bg);color:var(--success)}.settings-section-icon.amber{background:var(--warning-bg);color:var(--warning)}.settings-section-icon.blue{background:var(--info-bg);color:var(--info)}.settings-section-body{padding:22px 24px}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border-light)}.settings-row:last-child{border-bottom:none}.settings-row-label{font-size:13.5px;font-weight:600;color:var(--text)}.settings-row-desc{font-size:12px;color:var(--text-secondary);margin-top:1px}.settings-row-control{flex-shrink:0;margin-left:20px}.mono{font-family:var(--font-mono)}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-primary{color:var(--primary)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.font-bold{font-weight:700}.font-semibold{font-weight:600}.flex{display:flex}.flex-center{display:flex;align-items:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.gap-sm{gap:8px}.gap-md{gap:16px}.mt-sm{margin-top:8px}.mt-md{margin-top:16px}.mb-sm{margin-bottom:8px}.mb-md{margin-bottom:16px}.w-full{width:100%}.divider{height:1px;background:var(--border);margin:16px 0}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:10px;border:2px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}@keyframes shimmer{0%,to{opacity:1}50%{opacity:.55}}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes backdropIn{0%{opacity:0}to{opacity:1}}@keyframes toastIn{0%{opacity:0;transform:translateY(-8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes slideIn{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:900px){.env-grid,.bp-grid{grid-template-columns:1fr}}@media(max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.mobile-open{transform:translate(0)}.main{margin-left:0}.stats-grid{grid-template-columns:1fr}.content{padding:20px 16px}.topbar{padding:0 16px}.page-header{flex-direction:column;align-items:flex-start}}.btn.btn--primary{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 1px 4px #6366f140}.btn.btn--primary:hover:not(:disabled){background:var(--primary-dark);border-color:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.btn.btn--ghost{background:var(--surface);color:var(--text-secondary);border-color:var(--border)}.btn.btn--ghost:hover:not(:disabled){background:var(--surface-2);color:var(--text);border-color:var(--text-muted)}.btn.btn--danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn.btn--danger:hover:not(:disabled){filter:brightness(.92)}.btn.btn--warn{background:var(--warning);color:#fff;border-color:var(--warning)}.btn.btn--warn:hover:not(:disabled){filter:brightness(.92)}.btn.btn--green{background:var(--success);color:#fff;border-color:var(--success)}.btn.btn--green:hover:not(:disabled){filter:brightness(.92)}.btn.btn--accent{background:var(--accent);color:#fff;border-color:var(--accent)}.btn.btn--accent:hover:not(:disabled){filter:brightness(.92);transform:translateY(-1px)}.btn.btn--sm{padding:6px 13px;font-size:12px}.btn.btn--sm svg{width:13px;height:13px}.btn.btn--xs{padding:4px 10px;font-size:11px}.btn.btn--xs svg{width:11px;height:11px}.spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}.spinner--xs{width:12px;height:12px;border-width:1.5px}.spinner--sm{width:14px;height:14px}.spinner--lg{width:28px;height:28px;border-width:3px}.dot{width:7px;height:7px;border-radius:50%;display:inline-block}.dot--error{background:var(--danger)}.dot--ok{background:var(--success)}.dot--info{background:var(--info)}.dot--warn{background:var(--warning)}.pill{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:12px;font-size:12px;font-weight:500}.pill--purple{background:var(--primary-bg);color:var(--primary)}.pill--orange{background:var(--warning-bg);color:var(--warning)}.pill--green{background:var(--success-bg);color:var(--success)}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600}.badge--green{background:var(--success-bg);color:var(--success)}.badge--gray{background:var(--surface-2);color:var(--text-secondary)}.modal--sm{max-width:420px}.modal--md{max-width:560px}.modal--lg{max-width:720px}.layout--dark{background:#011224;color:#e2e8f0}
