@import"https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap";.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;z-index:100;overflow:hidden}.sidebar:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent)}.sidebar-header{padding:var(--space-5);border-bottom:1px solid var(--border-color)}.sidebar-logo{display:flex;align-items:center;gap:var(--space-3)}.logo-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);border-radius:var(--radius-lg);color:#fff;box-shadow:0 4px 12px #6366f14d;position:relative;overflow:hidden}.logo-icon:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.2) 0%,transparent 100%)}.logo-icon svg{position:relative;z-index:1}.logo-text{font-size:1.25rem;font-weight:800;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.tenant-selector-wrap{position:relative}.tenant-selector{font:inherit;box-sizing:border-box;display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);margin:var(--space-4) var(--space-4) 0;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-fast)}.tenant-selector:hover{background:var(--bg-elevated);border-color:var(--border-light);transform:translateY(-1px)}.tenant-info{display:flex;align-items:center;gap:var(--space-3)}.tenant-avatar{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);border-radius:var(--radius-lg);font-size:.8125rem;font-weight:700;color:#fff;box-shadow:0 2px 8px #6366f14d;position:relative;overflow:hidden}.tenant-avatar:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.2) 0%,transparent 100%)}.tenant-details{display:flex;flex-direction:column}.tenant-name{font-size:.875rem;font-weight:600;color:var(--text-primary)}.tenant-slug{font-size:.75rem;color:var(--text-tertiary)}.tenant-chevron{color:var(--text-tertiary);transition:transform var(--transition-fast)}.tenant-selector:hover .tenant-chevron:not(.open){transform:rotate(180deg)}.tenant-chevron.open{transform:rotate(180deg)}.tenant-dropdown{position:absolute;left:var(--space-4);right:var(--space-4);top:calc(100% + 4px);max-height:240px;overflow-y:auto;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:0 8px 24px #00000040;z-index:200}.tenant-dropdown-item{width:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding:var(--space-3) var(--space-4);border:none;font:inherit;text-align:left;color:var(--text-primary);background:transparent;cursor:pointer}.tenant-dropdown-item:hover{background:var(--bg-tertiary)}.tenant-dropdown-item.active .tenant-dropdown-name{font-weight:600}.tenant-dropdown-check{color:var(--color-primary);font-size:.625rem}.new-project-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-2);margin:var(--space-4) var(--space-4);padding:var(--space-3);background:var(--gradient-primary);border-radius:var(--radius-xl);color:#fff;font-size:.875rem;font-weight:600;transition:all var(--transition-fast);box-shadow:0 4px 14px #6366f14d;position:relative;overflow:hidden}.new-project-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.15) 0%,transparent 100%)}.new-project-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f166,var(--shadow-glow)}.new-project-btn:active{transform:translateY(0)}.new-project-btn svg{position:relative;z-index:1}.new-project-btn span{position:relative;z-index:1}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--space-2) var(--space-3)}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}.nav-section{margin-bottom:var(--space-5)}.nav-section-title{padding:var(--space-2) var(--space-3);font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);margin-bottom:var(--space-1);border-radius:var(--radius-lg);font-size:.9375rem;font-weight:500;color:var(--text-secondary);transition:all var(--transition-fast);position:relative}.nav-item:hover{background:var(--bg-elevated);color:var(--text-primary)}.nav-item.active{background:var(--glass-bg);color:var(--accent-primary);font-weight:600}.nav-item.active:before{content:"";position:absolute;left:-12px;width:4px;height:24px;background:var(--gradient-primary);border-radius:0 var(--radius-full) var(--radius-full) 0;box-shadow:0 0 12px #6366f180}.nav-item svg{transition:transform var(--transition-fast)}.nav-item:hover svg{transform:scale(1.1)}.nav-item.active svg{color:var(--accent-primary)}.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:var(--space-3)}.cost-calculator-link{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1px dashed var(--border-light);color:var(--text-tertiary);font-size:.8125rem;font-weight:500;text-decoration:none;transition:all .15s ease}.cost-calculator-link:hover,.cost-calculator-link.active{color:var(--accent-primary);border-color:var(--accent-primary);background:var(--accent-primary-light)}.usage-card{padding:var(--space-4)}.usage-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3);font-size:.8125rem;font-weight:600;color:var(--text-secondary)}.usage-badge{padding:var(--space-1) var(--space-2);background:var(--accent-primary-light);border-radius:var(--radius-md);font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--accent-primary)}.usage-bar{height:6px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--space-3);box-shadow:var(--shadow-inner)}.usage-fill{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full);transition:width var(--transition-slow);box-shadow:0 0 10px #6366f14d;position:relative;overflow:hidden}.usage-fill:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:shimmer 2s infinite}.usage-text{font-size:.75rem;font-weight:500;color:var(--text-muted)}.mobile-menu-toggle{display:none;position:fixed;bottom:var(--space-4);right:var(--space-4);width:56px;height:56px;background:var(--gradient-primary);border-radius:var(--radius-full);color:#fff;box-shadow:0 4px 20px #6366f166;z-index:200;align-items:center;justify-content:center}.sidebar-collapsed .sidebar{width:var(--sidebar-collapsed-width)}.sidebar-collapsed .logo-text,.sidebar-collapsed .tenant-details,.sidebar-collapsed .nav-item span,.sidebar-collapsed .nav-section-title,.sidebar-collapsed .new-project-btn span,.sidebar-collapsed .usage-text,.sidebar-collapsed .usage-header span:first-child{display:none}.sidebar-collapsed .new-project-btn{margin:var(--space-4) var(--space-3)}.sidebar-collapsed .nav-item{justify-content:center;padding:var(--space-3)}.sidebar-collapsed .nav-item.active:before{left:0;width:3px}@media (max-width: 1024px){.sidebar{transform:translate(-100%);transition:transform var(--transition-base)}.sidebar-open .sidebar{transform:translate(0)}.mobile-menu-toggle{display:flex}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.nav-item{position:relative}.sidebar-collapsed .nav-item:hover:after{content:attr(data-label);position:absolute;left:100%;top:50%;transform:translateY(-50%);margin-left:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.8125rem;font-weight:500;color:var(--text-primary);white-space:nowrap;z-index:100;animation:fadeIn .15s ease-out}.notif-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:150}.notif-panel{position:absolute;top:calc(100% + var(--space-2));right:0;width:360px;max-height:480px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:0 20px 50px #00000080,0 0 0 1px #ffffff0d;z-index:200;animation:menuSlideIn .2s cubic-bezier(.16,1,.3,1);overflow:hidden;display:flex;flex-direction:column}.notif-panel:before{content:"";position:absolute;top:-6px;right:16px;width:12px;height:12px;background:var(--bg-secondary);border-left:1px solid var(--border-color);border-top:1px solid var(--border-color);transform:rotate(45deg)}.notif-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-color);background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%)}.notif-panel-title{display:flex;align-items:center;gap:var(--space-2);font-size:.875rem;font-weight:600;color:var(--text-primary)}.notif-count-badge{font-size:.6875rem;font-weight:600;padding:1px 6px;border-radius:10px;background:var(--accent-primary);color:#fff}.notif-clear-btn{font-size:.75rem;font-weight:500;color:var(--text-tertiary);background:none;border:none;cursor:pointer;padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);transition:all var(--transition-fast)}.notif-clear-btn:hover{color:var(--accent-primary);background:var(--bg-hover)}.notif-panel-body{overflow-y:auto;max-height:400px}.notif-empty{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-10) var(--space-4);color:var(--text-muted)}.notif-empty span{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.notif-empty p{font-size:.75rem;color:var(--text-muted);margin:0}.notif-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-color);transition:background var(--transition-fast)}.notif-item:last-child{border-bottom:none}.notif-clickable{cursor:pointer}.notif-clickable:hover{background:var(--bg-hover)}.notif-item-icon{padding-top:2px;flex-shrink:0}.notif-icon.notif-success{color:var(--accent-success)}.notif-icon.notif-error{color:var(--accent-error)}.notif-icon.notif-warning{color:var(--accent-warning)}.notif-icon.notif-info{color:var(--accent-primary)}.notif-item-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.notif-item-title{font-size:.8125rem;font-weight:600;color:var(--text-primary)}.notif-item-message{font-size:.75rem;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-item-time{font-size:.6875rem;color:var(--text-muted);margin-top:2px}.notif-dismiss-btn{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--text-muted);background:none;border:none;cursor:pointer;opacity:0;transition:all var(--transition-fast)}.notif-item:hover .notif-dismiss-btn{opacity:1}.notif-dismiss-btn:hover{color:var(--text-primary);background:var(--bg-elevated)}@media (max-width: 640px){.notif-panel{width:300px;right:-8px}}.header{position:fixed;top:0;left:var(--sidebar-width);right:0;height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);background:#09090bd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);z-index:100}.header:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent)}.header-left{display:flex;align-items:center;gap:var(--space-5);min-width:0;flex-wrap:wrap}.header-env-indicator{display:inline-flex;align-items:center;gap:var(--space-2);flex-shrink:0}.header-env-label{font-size:.6875rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.header-env-switch{display:inline-flex;padding:2px;gap:2px;border-radius:999px;background:#ffffff0d;border:1px solid var(--glass-border)}.header-env-chip{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;cursor:pointer;font-size:.6875rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:5px 10px;border-radius:999px;color:var(--text-muted);background:transparent;transition:background .15s ease,color .15s ease}.header-env-chip:hover{color:var(--text-primary)}.header-env-chip.active{color:var(--text-primary);background:#ffffff1f;box-shadow:0 1px #00000040}.header-env-hint{font-size:.6875rem;color:#facc15f2;max-width:220px;line-height:1.25}.header-title{font-size:1.25rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary);min-width:0;flex:1 1 auto}.header-center{flex:1;display:flex;justify-content:center;padding:0 var(--space-8)}.search-bar{position:relative;width:100%;max-width:520px}.search-icon{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);color:var(--text-muted);transition:color var(--transition-fast)}.search-input{width:100%;padding:var(--space-2) var(--space-4) var(--space-2) var(--space-10);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);color:var(--text-primary);font-size:.875rem;font-weight:500;transition:all var(--transition-fast)}.search-input:focus{outline:none;border-color:var(--accent-primary);background:var(--bg-tertiary);box-shadow:0 0 0 3px var(--accent-primary-light)}.search-input:focus+.search-icon{color:var(--accent-primary)}.search-input::placeholder{color:var(--text-muted)}.search-shortcut{position:absolute;right:var(--space-3);top:50%;transform:translateY(-50%);padding:var(--space-1) var(--space-2);background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.6875rem;font-family:var(--font-mono);font-weight:600;color:var(--text-tertiary)}.header-right{display:flex;align-items:center;gap:var(--space-2)}.header-link{font-size:.875rem;font-weight:500;color:var(--text-secondary);text-decoration:none;padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);transition:all var(--transition-fast)}.header-link:hover{background:var(--bg-elevated);color:var(--text-primary)}.header-icon-btn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);color:var(--text-secondary);transition:all var(--transition-fast);position:relative}.header-icon-btn:hover{background:var(--bg-elevated);color:var(--text-primary);transform:translateY(-1px)}.header-icon-btn:active{transform:translateY(0)}.howto-btn{position:relative}.howto-tooltip{position:absolute;bottom:-32px;left:50%;transform:translate(-50%) scale(.9);padding:4px 10px;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.7rem;font-weight:600;color:var(--text-primary);white-space:nowrap;pointer-events:none;opacity:0;transition:all .15s ease;z-index:50}.howto-btn:hover .howto-tooltip{opacity:1;transform:translate(-50%) scale(1)}.notif-container,.notification-btn{position:relative}.notification-btn.active{background:var(--bg-elevated);color:var(--text-primary)}.notification-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;background:var(--accent-error);border-radius:50%;border:2px solid var(--bg-primary)}.notification-dot:before{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;background:var(--accent-error);border-radius:50%;opacity:.4;animation:pulse-ring 2s cubic-bezier(.215,.61,.355,1) infinite}.user-menu-container{position:relative}.user-menu-trigger{display:flex;align-items:center;padding:var(--space-1);border-radius:var(--radius-full);transition:all var(--transition-fast);border:2px solid transparent;background:transparent}.user-menu-trigger:hover,.user-menu-trigger.active{background:var(--bg-elevated);border-color:var(--border-color)}.user-avatar{width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);border-radius:var(--radius-full);font-size:.875rem;font-weight:700;color:#fff;box-shadow:0 2px 8px #6366f14d;position:relative;overflow:hidden}.user-avatar:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.2) 0%,transparent 100%)}.user-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:150}.user-menu-dropdown{position:absolute;top:calc(100% + var(--space-2));right:0;width:280px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:0 20px 50px #00000080,0 0 0 1px #ffffff0d;z-index:200;animation:menuSlideIn .2s cubic-bezier(.16,1,.3,1);overflow:hidden}@keyframes menuSlideIn{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.user-menu-dropdown:before{content:"";position:absolute;top:-6px;right:16px;width:12px;height:12px;background:var(--bg-secondary);border-left:1px solid var(--border-color);border-top:1px solid var(--border-color);transform:rotate(45deg)}.user-menu-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%);border-bottom:1px solid var(--border-color)}.user-avatar-lg{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);border-radius:var(--radius-full);font-size:1.25rem;font-weight:700;color:#fff;box-shadow:0 4px 12px #6366f14d;position:relative;overflow:hidden;flex-shrink:0}.user-avatar-lg:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.2) 0%,transparent 100%)}.user-info{display:flex;flex-direction:column;gap:var(--space-1);min-width:0;overflow:hidden}.user-name{font-size:.9375rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:.8125rem;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-menu-divider{height:1px;background:var(--border-color);margin:var(--space-2) 0}.user-menu-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);font-size:.875rem;font-weight:500;color:var(--text-secondary);transition:all var(--transition-fast);background:transparent;text-align:left}.user-menu-item:hover{background:var(--bg-elevated);color:var(--text-primary)}.user-menu-item svg{color:var(--text-tertiary);flex-shrink:0}.user-menu-item:hover svg{color:var(--text-secondary)}.user-menu-item:last-child{margin-bottom:var(--space-2)}.search-placeholder{width:100%;padding:var(--space-2) var(--space-4) var(--space-2) var(--space-10);color:var(--text-muted);font-size:.875rem;font-weight:500;cursor:pointer;-webkit-user-select:none;user-select:none}.search-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:500;animation:fadeIn .15s ease}.search-modal{position:fixed;top:20%;left:50%;transform:translate(-50%);width:560px;max-width:calc(100% - 40px);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:0 25px 60px #00000080,0 0 0 1px #ffffff0d;z-index:501;overflow:hidden;animation:searchSlideIn .2s cubic-bezier(.16,1,.3,1)}@keyframes searchSlideIn{0%{opacity:0;transform:translate(-50%) translateY(-10px) scale(.97)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.search-modal-input-wrap{display:flex;align-items:center;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-color);gap:var(--space-3)}.search-modal-icon{color:var(--text-muted);flex-shrink:0}.search-modal-input{flex:1;background:none;border:none;color:var(--text-primary);font-size:1rem;font-weight:500;outline:none}.search-modal-input::placeholder{color:var(--text-muted)}.search-modal-esc{padding:2px 6px;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.6875rem;font-family:var(--font-mono);font-weight:600;color:var(--text-tertiary);flex-shrink:0}.search-modal-results{max-height:340px;overflow-y:auto;padding:var(--space-2) 0}.search-section-title{font-size:.6875rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;padding:var(--space-2) var(--space-4) var(--space-1)}.search-result-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-2) var(--space-4);background:none;border:none;color:var(--text-secondary);font-size:.875rem;text-align:left;cursor:pointer;transition:background var(--transition-fast)}.search-result-item:hover,.search-result-item.selected{background:var(--bg-hover);color:var(--text-primary)}.search-result-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-tertiary);flex-shrink:0}.search-result-item.selected .search-result-icon,.search-result-item:hover .search-result-icon{color:var(--accent-primary);background:var(--accent-primary-light)}.search-result-info{flex:1;display:flex;flex-direction:column;min-width:0}.search-result-label{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-result-desc{font-size:.75rem;color:var(--text-muted)}.search-result-type{font-size:.6875rem;font-weight:500;color:var(--text-muted);padding:1px 8px;border-radius:var(--radius-md);background:var(--bg-elevated);flex-shrink:0}.search-no-results{padding:var(--space-6) var(--space-4);text-align:center;color:var(--text-muted);font-size:.875rem}.breadcrumb{display:flex;align-items:center;gap:var(--space-2);font-size:.875rem;color:var(--text-tertiary)}.breadcrumb-item{display:flex;align-items:center;gap:var(--space-2)}.breadcrumb-item a{color:var(--text-secondary);transition:color var(--transition-fast)}.breadcrumb-item a:hover{color:var(--accent-primary)}.breadcrumb-separator{color:var(--text-muted)}.breadcrumb-current{color:var(--text-primary);font-weight:500}@media (max-width: 1024px){.header{left:0}.header-center{display:none}.header-title{font-size:1.125rem}}@media (max-width: 640px){.header{padding:0 var(--space-4)}.header-icon-btn:not(.notification-btn){display:none}.user-menu-dropdown{width:260px;right:-8px}}.dashboard-layout{min-height:100vh;background:var(--bg-primary);position:relative}.dashboard-layout:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 30%,rgba(99,102,241,.03) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(168,85,247,.03) 0%,transparent 50%),radial-gradient(circle at 50% 50%,rgba(99,102,241,.01) 0%,transparent 70%);pointer-events:none;z-index:0}.main-content{margin-left:var(--sidebar-width);margin-top:var(--header-height);padding:var(--space-6);min-height:calc(100vh - var(--header-height));position:relative;z-index:1}.page-content{animation:pageEnter .4s cubic-bezier(.16,1,.3,1)}@keyframes pageEnter{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.page-exit{animation:pageExit .3s cubic-bezier(.4,0,1,1) forwards}@keyframes pageExit{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}.page-transition-container{position:relative}.page-transition-container>*{animation:pageEnter .4s cubic-bezier(.16,1,.3,1)}.content-stagger>*{opacity:0;animation:contentFadeIn .4s cubic-bezier(.16,1,.3,1) forwards}.content-stagger>*:nth-child(1){animation-delay:.05s}.content-stagger>*:nth-child(2){animation-delay:.1s}.content-stagger>*:nth-child(3){animation-delay:.15s}.content-stagger>*:nth-child(4){animation-delay:.2s}.content-stagger>*:nth-child(5){animation-delay:.25s}.content-stagger>*:nth-child(6){animation-delay:.3s}.content-stagger>*:nth-child(7){animation-delay:.35s}.content-stagger>*:nth-child(8){animation-delay:.4s}@keyframes contentFadeIn{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.maintenance-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#000000d9;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:var(--space-6)}.maintenance-card{background:var(--bg-secondary);border:1px solid rgba(245,158,11,.3);border-radius:var(--radius-xl);padding:var(--space-12) var(--space-10);max-width:480px;width:100%;text-align:center;box-shadow:0 0 60px #f59e0b1a,0 24px 64px #00000080}.maintenance-icon{font-size:3rem;margin-bottom:var(--space-5);display:block;animation:maintenance-pulse 2s ease-in-out infinite}@keyframes maintenance-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.maintenance-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 var(--space-3)}.maintenance-message{font-size:.9375rem;color:var(--text-secondary);line-height:1.6;margin:0 0 var(--space-6)}.maintenance-badge{display:inline-flex;align-items:center;gap:var(--space-2);background:#f59e0b1a;border:1px solid rgba(245,158,11,.25);color:#f59e0b;font-size:.8125rem;font-weight:600;padding:var(--space-2) var(--space-4);border-radius:var(--radius-full)}.maintenance-dot{width:8px;height:8px;border-radius:50%;background:#f59e0b;animation:maintenance-blink 1.2s ease-in-out infinite}@keyframes maintenance-blink{0%,to{opacity:1}50%{opacity:.2}}@media (max-width: 1024px){.dashboard-layout .sidebar{transform:translate(-100%);transition:transform var(--transition-base)}.dashboard-layout.sidebar-open .sidebar{transform:translate(0)}.main-content{margin-left:0;padding:var(--space-4)}.header{left:0}}@media (max-width: 640px){.main-content{padding:var(--space-3)}}.main-content::-webkit-scrollbar{width:8px}.main-content::-webkit-scrollbar-track{background:transparent}.main-content::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}.main-content::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.main-content *:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.main-content ::selection{background:var(--accent-primary-light);color:var(--text-primary)}.auth-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6);position:relative;overflow:hidden}.auth-background{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1}.auth-bg-gradient{position:absolute;width:600px;height:600px;top:-200px;right:-100px;background:radial-gradient(circle,rgba(59,130,246,.15) 0%,transparent 70%);filter:blur(60px)}.auth-bg-gradient:after{content:"";position:absolute;width:400px;height:400px;bottom:-100px;left:-100px;background:radial-gradient(circle,rgba(139,92,246,.1) 0%,transparent 70%);filter:blur(60px)}.auth-bg-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse at center,black 30%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse at center,black 30%,transparent 70%)}.auth-card{width:100%;max-width:420px;padding:var(--space-8)}.auth-header{text-align:center;margin-bottom:var(--space-6)}.auth-logo{display:flex;justify-content:center;margin-bottom:var(--space-4)}.auth-logo .logo-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);border-radius:var(--radius-lg);color:#fff;box-shadow:var(--shadow-lg),var(--shadow-glow)}.auth-title{font-size:1.5rem;font-weight:700;margin-bottom:var(--space-2)}.auth-subtitle{font-size:.875rem;color:var(--text-secondary)}.auth-error{padding:var(--space-3) var(--space-4);background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:var(--accent-error);font-size:.875rem;margin-bottom:var(--space-4);text-align:center}.auth-form{margin-bottom:var(--space-4)}.input-wrapper{position:relative}.input-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-muted);z-index:1;pointer-events:none}.input-wrapper .input.input-with-icon{padding-left:3.5rem}.input-wrapper .input:focus+.input-icon,.input-wrapper .input:not(:placeholder-shown)+.input-icon{color:var(--accent-primary)}.input-wrapper .input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #6366f11a}.input-label-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.input-link{font-size:.8125rem;color:var(--accent-primary);transition:color var(--transition-fast)}.input-link:hover{color:var(--accent-primary-hover)}.input-hint{display:block;margin-top:var(--space-2);font-size:.75rem;color:var(--text-muted)}.verification-input{text-align:center;font-size:1.5rem;letter-spacing:.5em;font-weight:600}.auth-submit{width:100%;margin-top:var(--space-4)}.auth-footer{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding-top:var(--space-4);border-top:1px solid var(--border-color);font-size:.875rem;color:var(--text-secondary)}.auth-link{color:var(--accent-primary);font-weight:500;transition:color var(--transition-fast)}.auth-link:hover{color:var(--accent-primary-hover)}.auth-terms{margin-top:var(--space-6);font-size:.75rem;color:var(--text-muted);text-align:center}.auth-terms a{color:var(--text-secondary);text-decoration:underline}.auth-terms a:hover{color:var(--text-primary)}.auth-divider{display:flex;align-items:center;gap:var(--space-4);margin:var(--space-4) 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.auth-divider span{font-size:.75rem;color:var(--text-muted);text-transform:uppercase}.social-buttons{display:flex;gap:var(--space-3)}.social-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;font-weight:500;transition:all var(--transition-fast)}.social-btn:hover{background:var(--bg-elevated);border-color:var(--border-light)}.dashboard{max-width:1400px;animation:fadeIn .4s ease-out}.dashboard-header{margin-bottom:var(--space-8)}.dashboard-header h2{font-size:1.875rem;font-weight:700;letter-spacing:-.02em;background:linear-gradient(180deg,var(--text-primary) 0%,var(--text-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-5);margin-bottom:var(--space-10)}.stat-card{display:flex;align-items:center;gap:var(--space-5);padding:var(--space-6);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,currentColor,transparent);opacity:0;transition:opacity var(--transition-base)}.stat-card:hover:before{opacity:.3}.stat-icon{width:52px;height:52px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-xl);position:relative;flex-shrink:0}.stat-icon:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius-xl);opacity:.15;background:currentColor}.stat-content{display:flex;flex-direction:column;min-width:0}.stat-value{font-size:2rem;font-weight:800;line-height:1;letter-spacing:-.02em;background:linear-gradient(180deg,var(--text-primary) 0%,var(--text-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-label{font-size:.8125rem;color:var(--text-tertiary);margin-top:var(--space-1);font-weight:500}.stat-trend{display:flex;align-items:center;gap:var(--space-1);font-size:.75rem;font-weight:600;margin-top:var(--space-1)}.stat-trend.positive{color:var(--accent-success)}.stat-trend.negative{color:var(--accent-error)}.dashboard-section{margin-bottom:var(--space-10)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-5)}.section-header h3{font-size:1.125rem;font-weight:600;letter-spacing:-.01em;display:flex;align-items:center;gap:var(--space-2)}.section-link{display:flex;align-items:center;gap:var(--space-1);font-size:.875rem;font-weight:500;color:var(--accent-primary);transition:all var(--transition-fast);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md)}.section-link:hover{background:var(--accent-primary-light);gap:var(--space-2)}.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-5)}.project-card{padding:var(--space-5);cursor:pointer;transition:all var(--transition-slow);position:relative;display:flex;flex-direction:column;min-height:160px}.project-card:hover{transform:translateY(-4px)}.project-card:hover .project-menu{opacity:1;transform:scale(1)}.project-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.project-avatar{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);border-radius:var(--radius-lg);font-size:1.125rem;font-weight:700;color:#fff;box-shadow:0 4px 12px #6366f14d;position:relative;overflow:hidden}.project-avatar:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.2) 0%,transparent 100%)}.project-menu-container{position:relative}.project-menu{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--text-tertiary);opacity:0;transform:scale(.8);transition:all var(--transition-fast);background:var(--bg-elevated)}.project-menu:hover{background:var(--bg-hover);color:var(--text-primary)}.project-dropdown{position:absolute;top:100%;right:0;margin-top:var(--space-2);min-width:180px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl),0 0 0 1px #0003;padding:var(--space-2);z-index:100;animation:dropdownFadeIn .2s cubic-bezier(.16,1,.3,1)}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.dropdown-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-2) var(--space-3);font-size:.875rem;font-weight:500;color:var(--text-secondary);border-radius:var(--radius-md);transition:all var(--transition-fast);text-align:left}.dropdown-item-danger:hover{background:var(--accent-error-light);color:var(--accent-error)}.project-info{flex:1;margin-bottom:var(--space-4)}.project-name{font-size:1rem;font-weight:600;margin-bottom:var(--space-1);letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-url{font-size:.8125rem;color:var(--text-tertiary);display:flex;align-items:center;gap:var(--space-1)}.project-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto}.project-external{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--text-tertiary);transition:all var(--transition-fast);background:transparent}.project-external:hover{background:var(--accent-primary-light);color:var(--accent-primary)}.deployments-list{padding:0;overflow:hidden}.deployment-row{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-color);transition:all var(--transition-fast)}.deployment-status{width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.status-building{width:18px;height:18px;border:2px solid var(--accent-warning);border-top-color:transparent;border-radius:50%;animation:spin 1s linear infinite}.deployment-info{flex:1;display:flex;flex-direction:column;gap:var(--space-1);min-width:0}.deployment-message{font-size:.9375rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.deployment-meta{display:flex;align-items:center;gap:var(--space-2);font-size:.8125rem;color:var(--text-tertiary)}.deployment-meta .dot{width:4px;height:4px;background:var(--text-muted);border-radius:50%}.deployment-actions{display:flex;align-items:center;gap:var(--space-2)}.empty-state{padding:var(--space-16);text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-6)}.empty-icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center;font-size:2.5rem;background:var(--glass-bg);border-radius:var(--radius-2xl);margin-bottom:var(--space-2)}.empty-state p{color:var(--text-secondary);font-size:.9375rem;max-width:400px;margin:0 auto var(--space-4)}.loading-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}.badge-enhanced{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-full);border:1px solid transparent}.badge-enhanced-success{background:var(--accent-success-light);color:var(--accent-success);border-color:#22c55e33}.badge-enhanced-warning{background:var(--accent-warning-light);color:var(--accent-warning);border-color:#f59e0b33}.badge-enhanced-error{background:var(--accent-error-light);color:var(--accent-error);border-color:#ef444433}.quick-actions-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);margin-bottom:var(--space-8)}.quick-action-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-6);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-xl);color:var(--text-secondary);transition:all var(--transition-base);cursor:pointer}.quick-action-btn:hover{background:var(--glass-bg-hover);border-color:var(--glass-border-hover);color:var(--text-primary);transform:translateY(-2px)}.quick-action-btn svg{color:var(--accent-primary)}.quick-action-btn span{font-size:.875rem;font-weight:500}.welcome-banner{background:var(--gradient-primary);border-radius:var(--radius-2xl);padding:var(--space-8);margin-bottom:var(--space-8);position:relative;overflow:hidden}.welcome-banner:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 80%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,255,255,.05) 0%,transparent 50%)}.welcome-content{position:relative;z-index:1}.welcome-title{font-size:1.5rem;font-weight:700;color:#fff;margin-bottom:var(--space-2)}.welcome-subtitle{font-size:1rem;color:#fffc;max-width:500px}.activity-timeline{position:relative;padding-left:var(--space-6)}.activity-timeline:before{content:"";position:absolute;left:11px;top:0;bottom:0;width:2px;background:var(--border-color)}.timeline-item{position:relative;padding-bottom:var(--space-5)}.timeline-item:before{content:"";position:absolute;left:-21px;top:4px;width:10px;height:10px;border-radius:50%;background:var(--bg-elevated);border:2px solid var(--border-color)}.timeline-item.success:before{background:var(--accent-success);border-color:var(--accent-success)}.timeline-item.error:before{background:var(--accent-error);border-color:var(--accent-error)}.timeline-item.building:before{background:var(--accent-warning);border-color:var(--accent-warning);animation:pulse 2s infinite}@media (max-width: 1280px){.stats-grid,.quick-actions-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 1024px){.projects-grid,.loading-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.dashboard{padding:var(--space-4)}.stats-grid{grid-template-columns:1fr;gap:var(--space-4)}.projects-grid{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.quick-actions-grid{grid-template-columns:repeat(2,1fr)}.welcome-banner{padding:var(--space-6)}.welcome-title{font-size:1.25rem}}@media (max-width: 480px){.quick-actions-grid{grid-template-columns:1fr}.stat-card{padding:var(--space-4)}.stat-icon{width:44px;height:44px}.stat-value{font-size:1.5rem}}.danger-zone{border:1px solid rgba(239,68,68,.3)!important;background:#ef444408!important}.danger-zone-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-6);border-bottom:1px solid rgba(239,68,68,.15);color:var(--accent-error)}.danger-zone-header h3{font-size:1rem;font-weight:600;margin:0;color:var(--accent-error)}.danger-zone-content{padding:var(--space-5) var(--space-6)}.danger-zone-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-6)}.danger-zone-info h4{font-size:.9375rem;font-weight:600;margin-bottom:var(--space-1)}.danger-zone-info p{font-size:.8125rem;color:var(--text-tertiary);line-height:1.5;margin:0}.delete-warning{font-size:.9375rem;line-height:1.6;margin-bottom:var(--space-4)}.delete-resources-list{list-style:none;padding:0;margin:0 0 var(--space-5);display:flex;flex-direction:column;gap:var(--space-2)}.delete-resources-list li{display:flex;align-items:center;gap:var(--space-2);font-size:.8125rem;color:var(--text-secondary);padding:var(--space-2) var(--space-3);background:#ef44440d;border-radius:var(--radius-md);border-left:3px solid rgba(239,68,68,.3)}.delete-resources-list li:before{content:"•";color:var(--accent-error);font-weight:700;font-size:1.25rem;line-height:1}.delete-confirm-input{margin-top:var(--space-4)}.delete-confirm-input label{display:block;font-size:.875rem;font-weight:500;margin-bottom:var(--space-2);color:var(--text-secondary)}.delete-confirm-input .input{width:100%;box-sizing:border-box}.delete-progress{padding:var(--space-6) 0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.modal{width:90%;max-width:480px;max-height:90vh;overflow-y:auto;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color)}.modal-header h2{font-size:1.125rem;font-weight:600;display:flex;align-items:center}.modal-body{padding:var(--space-5) var(--space-6)}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-color)}@media (max-width: 768px){.danger-zone-item{flex-direction:column;align-items:flex-start}.danger-zone-item .btn{align-self:flex-end}}.dash-skeleton-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}.dash-page-header{margin-bottom:var(--space-6)}.dash-page-title{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary);margin-bottom:4px}.dash-page-subtitle{font-size:.8125rem;color:var(--text-tertiary)}.dash-stats-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}.dash-stat-card{display:flex;align-items:flex-start;gap:var(--space-4);padding:var(--space-5);position:relative;overflow:hidden}.dash-stat-icon{flex-shrink:0;width:44px;height:44px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center}.dash-icon-indigo{background:#6366f126;color:#818cf8}.dash-icon-green{background:#22c55e1f;color:#4ade80}.dash-icon-purple{background:#7000ff26;color:#a78bfa}.dash-icon-amber{background:#f59e0b1f;color:#fbbf24}.dash-icon-cyan{background:#06b6d41f;color:#22d3ee}.dash-stat-body{flex:1;min-width:0}.dash-stat-label{font-size:.625rem;font-weight:700;letter-spacing:.08em;color:var(--text-tertiary);text-transform:uppercase;margin-bottom:6px}.dash-stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:6px;letter-spacing:-.02em}.dash-stat-denom{font-size:1rem;color:var(--text-tertiary);font-weight:500}.dash-stat-sub{font-size:.7rem;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-chart-card{padding:var(--space-5);margin-bottom:var(--space-5)}.dash-chart-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-5)}.dash-chart-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:2px}.dash-chart-subtitle{font-size:.75rem;color:var(--text-tertiary)}.dash-chart-link{font-size:.75rem;color:var(--accent-primary);text-decoration:none;white-space:nowrap;padding-top:2px}.dash-chart-link:hover{text-decoration:underline}.dash-range-btns{display:flex;gap:4px;background:var(--bg-elevated);border-radius:var(--radius-md);padding:3px}.dash-range-btn{padding:4px 12px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;color:var(--text-tertiary);background:transparent;border:none;cursor:pointer;transition:all var(--transition-fast)}.dash-range-btn.active{background:var(--accent-primary);color:#fff}.dash-range-btn:hover:not(.active){color:var(--text-primary)}.dash-charts-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5)}.dash-chart-half{margin-bottom:0}.dash-pie-wrap{display:flex;align-items:center;gap:var(--space-4)}.dash-pie-legend{flex:1;display:flex;flex-direction:column;gap:var(--space-2)}.dash-pie-row{display:flex;align-items:center;gap:var(--space-2);font-size:.8125rem}.dash-pie-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.dash-pie-name{flex:1;color:var(--text-secondary)}.dash-pie-count{font-weight:600;color:var(--text-primary)}.dash-pie-total{border-top:1px solid var(--border-color);margin-top:var(--space-1);padding-top:var(--space-2)}.dash-empty-chart{display:flex;flex-direction:column;align-items:center;justify-content:center;height:160px;gap:var(--space-3);color:var(--text-tertiary);font-size:.875rem}.recharts-tooltip-wrapper{outline:none}@media (max-width: 1200px){.dash-stats-grid,.dash-skeleton-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 900px){.dash-stats-grid{grid-template-columns:repeat(2,1fr)}.dash-charts-row{grid-template-columns:1fr}.dash-skeleton-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.dash-stats-grid{grid-template-columns:1fr}}.external-notice-badge{display:inline-flex;align-items:center;flex-shrink:0;font-size:.625rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:0 .5rem;border-radius:4px;background:#38bdf81f;color:#38bdf8;border:1px solid rgba(56,189,248,.35)}.external-notice-banner{display:flex;flex-direction:column;gap:.35rem;padding:.75rem 1rem;border-radius:10px;background:linear-gradient(135deg,#38bdf814,#94a3b80f);border:1px solid rgba(56,189,248,.22);border-left:3px solid #38bdf8}.external-notice-banner-top{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.external-notice-banner-title{font-size:.8125rem;font-weight:600;color:var(--text-primary, #e2e8f0)}.external-notice-desc{margin:0;font-size:.8125rem;line-height:1.45;color:var(--text-secondary, #94a3b8);max-width:52rem}.external-notice-card{margin:0 0 1rem;padding:.65rem .85rem;border-radius:8px;background:#38bdf80f;border:1px solid rgba(56,189,248,.18)}.external-notice-card .external-notice-desc{font-size:.75rem;margin-top:.35rem}.external-notice-stripe{display:flex;align-items:center;gap:.5rem;padding:.45rem .75rem;border-radius:8px;background:#38bdf814;border:1px solid rgba(56,189,248,.22);border-left:3px solid #38bdf8;min-height:0}.external-notice-stripe-text{font-size:.75rem;line-height:1.35;color:var(--text-secondary, #94a3b8);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.external-notice-app-tag{display:inline-flex;align-items:center;margin-top:.2rem}.external-notice-app-tag .external-notice-badge{font-size:.5625rem;padding:.12rem .4rem}.external-notice-inline{display:inline-flex;align-items:center;margin-left:auto}.external-notice-chip{display:inline-flex;align-items:center;font-size:.625rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:.15rem .45rem;border-radius:4px;background:#38bdf81f;color:#38bdf8;border:1px solid rgba(56,189,248,.3);flex-shrink:0}.platform-pipeline-header-main .external-notice-banner{margin:0 0 .75rem;width:100%}.platform-env-pipeline .external-notice-banner{margin-top:0}.app-external-notice{margin:0 0 1.25rem}.apps-page{max-width:1400px}.apps-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6);flex-wrap:wrap;gap:var(--space-4)}.apps-runtime-hint{font-size:.8125rem;color:var(--text-secondary);margin:calc(-1 * var(--space-3)) 0 var(--space-5);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);border:1px solid rgba(250,204,21,.35);background:#facc150f}.apps-title-section{display:flex;align-items:baseline;gap:var(--space-3)}.apps-title-section h2{font-size:1.5rem;font-weight:700}.apps-count{font-size:.875rem;color:var(--text-tertiary)}.apps-load-error-card{margin-top:var(--space-4)}.platform-load-sentinel{min-height:12px;display:flex;align-items:center;justify-content:center}.platform-load-more{display:inline-flex;align-items:center;gap:var(--space-2);font-size:.875rem;color:var(--text-tertiary);padding:var(--space-4) 0 var(--space-2)}.apps-actions{display:flex;align-items:center;gap:var(--space-3)}.apps-search{position:relative;width:280px}.apps-search .search-icon{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);color:var(--text-muted)}.apps-search .input{padding-left:var(--space-10)}.platform-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-6);row-gap:calc(var(--space-6) + var(--space-6))}.platform-env-highlight{position:relative;display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-5) var(--space-5) var(--space-4);grid-column:1 / -1}.platform-env-highlight:before{content:"";position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px;border-radius:calc(var(--radius-xl) + 12px);background:radial-gradient(900px 380px at 18% 42%,rgba(139,92,246,.26),transparent 58%),radial-gradient(900px 380px at 50% 58%,rgba(249,115,22,.22),transparent 58%),radial-gradient(900px 380px at 84% 40%,rgba(34,197,94,.22),transparent 58%);filter:blur(14px);opacity:.95;pointer-events:none;z-index:0}.platform-env-highlight:after{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:calc(var(--radius-xl) + 10px);background:#0f172a59;border:1px solid rgba(255,255,255,.12);box-shadow:0 0 0 1px #6366f114 inset,0 22px 72px #0000006b,0 0 48px #581c871f;pointer-events:none;z-index:0}.platform-env-highlight .platform-pipeline-header{position:relative;z-index:20}.platform-env-highlight .platform-env-cards-row{position:relative;z-index:2}.platform-env-highlight .platform-summary-bar{position:relative;z-index:1}.platform-pipeline-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:var(--space-4);padding:0 var(--space-1)}.platform-pipeline-header-main{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3) var(--space-6);flex:1 1 240px;min-width:0}.platform-pipeline-menu{display:inline-flex;flex-shrink:0;align-items:center;gap:var(--space-2);position:relative;z-index:30}.platform-pipeline-menu-trigger{opacity:1!important;transform:scale(1)!important}.platform-pipeline-menu .app-dropdown.platform-pipeline-dropdown{top:auto;bottom:calc(100% + var(--space-2));margin-top:0;z-index:2000;animation:platformPipelineDropdownFade .16s ease-out}@keyframes platformPipelineDropdownFade{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.platform-connected-pill{display:inline-flex;align-items:center;gap:var(--space-2);padding:6px 14px;border-radius:999px;font-size:.75rem;font-weight:600;letter-spacing:.02em;color:#e0e7ffeb;background:linear-gradient(135deg,#581c8773,#312e8159);border:1px solid rgba(167,139,250,.35);box-shadow:0 0 24px #7c3aed38}.platform-pipeline-sub{margin:0;flex:1 1 200px;font-size:.8125rem;color:#e2e8f085;line-height:1.45}.platform-env-cards-row{display:flex;flex-direction:row;align-items:stretch;gap:0}.platform-env-connector{display:flex;align-items:center;width:36px;flex-shrink:0;align-self:center;opacity:.85}.platform-env-connector-line{flex:1;min-width:8px;height:0;border-top:2px dotted rgba(226,232,240,.35)}.platform-env-connector-node{width:8px;height:8px;border-radius:50%;background:#f8fafce6;box-shadow:0 0 10px #ffffff59;flex-shrink:0}.platform-env-card{flex:1 1 0;align-self:stretch;min-width:0;display:flex;flex-direction:column;align-items:flex-start;text-decoration:none;color:inherit;border-radius:28px;padding:var(--space-5) var(--space-5) var(--space-4);min-height:320px;cursor:pointer;transition:transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s ease,border-color .25s ease;position:relative;overflow:hidden;--env-accent-glow: rgba(124, 58, 237, .45)}.platform-env-card.glass-card{background:linear-gradient(165deg,#1e293bc7,#0f172ab8);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.1);box-shadow:0 4px 28px #00000073,0 0 0 1px #ffffff0a inset}.platform-env-card--development{--env-accent: #a855f7;--env-accent-soft: rgba(168, 85, 247, .2);--env-accent-glow: rgba(168, 85, 247, .42)}.platform-env-card--staging{--env-accent: #f97316;--env-accent-soft: rgba(249, 115, 22, .2);--env-accent-glow: rgba(249, 115, 22, .4)}.platform-env-card--production{--env-accent: #22c55e;--env-accent-soft: rgba(34, 197, 94, .2);--env-accent-glow: rgba(34, 197, 94, .42)}.platform-env-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;padding:1px;background:linear-gradient(145deg,var(--env-accent-glow),transparent 42%,transparent 58%,var(--env-accent-glow));mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask-composite:exclude;-webkit-mask-composite:xor;pointer-events:none;opacity:.55}.platform-env-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #0000008c,0 0 48px var(--env-accent-glow),0 0 0 1px #ffffff14 inset}.platform-env-card:hover:before{opacity:.9}.platform-env-card-top{width:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);margin-bottom:var(--space-4)}.platform-env-badge{font-size:.6875rem;font-weight:800;letter-spacing:.1em;padding:5px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.14)}.platform-env-badge--development{color:#e9d5fff2;background:#7c3aed40;border-color:#a78bfa73;box-shadow:0 0 20px #7c3aed40}.platform-env-badge--staging{color:#ffedd5f5;background:#ea580c38;border-color:#fb923c80;box-shadow:0 0 20px #f9731633}.platform-env-badge--production{color:#d1fae5f5;background:#15803d47;border-color:#4ade8073;box-shadow:0 0 20px #22c55e38}.platform-env-card-health{display:inline-flex;align-items:center;gap:6px;font-size:.75rem;font-weight:600;color:#e2e8f0bf}.platform-env-card-illustration{width:100%;min-height:108px;max-height:136px;height:128px;border-radius:16px;margin-bottom:var(--space-4);flex-shrink:0;display:flex;align-items:center;justify-content:center;background:transparent;overflow:visible}.platform-env-card-illustration--development{box-shadow:0 10px 26px #7c3aed59;outline:1px solid rgba(167,139,250,.25)}.platform-env-card-illustration--staging{box-shadow:0 10px 26px #ea580c47;outline:1px solid rgba(251,146,60,.28)}.platform-env-card-illustration--production{box-shadow:0 10px 26px #15803d59;outline:1px solid rgba(74,222,128,.25)}.platform-env-card-title{margin:0 0 var(--space-2);font-size:1.125rem;font-weight:700;color:#f8fafcf5;line-height:1.25;width:100%}.platform-env-card-org{margin:0 0 var(--space-3);display:flex;align-items:center;gap:6px;font-size:.75rem;color:#94a3b8f2;width:100%}.platform-env-card-desc{margin:0 0 var(--space-4);font-size:.8125rem;line-height:1.5;color:#cbd5e1b8;flex:0 0 auto}.platform-env-card-stats{list-style:none;margin:0 0 var(--space-3);padding:0;width:100%;display:flex;flex-direction:column;gap:10px}.platform-env-card-stats li{display:grid;grid-template-columns:18px 1fr auto;align-items:center;gap:8px 10px;font-size:.75rem}.platform-env-stat-ic{color:#94a3b8d9}.platform-env-stat-label{color:#94a3b8e0}.platform-env-stat-value{font-weight:600;color:#f8fafceb;text-align:right}.platform-env-card-stack-preview{display:flex;flex-wrap:wrap;justify-content:flex-start;align-items:flex-start;gap:6px 8px;width:100%;margin-top:2px;padding-bottom:10px;padding-left:6px;box-sizing:border-box}.platform-env-stack-cell{display:flex;flex-direction:column;align-items:flex-start;gap:2px;flex:0 0 auto;min-width:48px;max-width:76px}.platform-env-stack-icon-wrap{display:flex;align-items:center;justify-content:flex-start;width:36px;height:32px;padding:0;background:transparent;border:none;box-shadow:none}.platform-env-stack-icon-wrap .platform-stack-icon{width:26px;height:26px;object-fit:contain;display:block}.platform-env-stack-icon-wrap svg{width:22px;height:22px;flex-shrink:0;color:#e2e8f0e6;stroke-width:2}.platform-env-stack-label{font-size:.6875rem;font-weight:600;line-height:1.15;text-align:left;align-self:stretch;color:#cbd5e1f2;letter-spacing:.01em;word-break:break-word}.platform-env-card-cta{margin-top:auto;flex-shrink:0;padding-top:var(--space-3);border-top:1px solid rgba(255,255,255,.12);width:100%;box-sizing:border-box;display:inline-flex;align-items:center;gap:4px;font-size:.8125rem;font-weight:600;transition:gap .2s ease}.platform-env-card-cta--development{color:#c084fc}.platform-env-card-cta--staging{color:#fb923c}.platform-env-card-cta--production{color:#4ade80}.platform-env-card:hover .platform-env-card-cta{gap:8px}.platform-summary-bar{display:flex;flex-wrap:wrap;align-items:stretch;gap:var(--space-4);padding:var(--space-4) var(--space-5);border-radius:22px;background:#0f172ad1;border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px #00000059}.platform-summary-brand{display:flex;align-items:center;gap:var(--space-3);min-width:180px;flex:1 1 200px}.platform-summary-icon{width:44px;height:44px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6366f159,#7c3aed33);border:1px solid rgba(129,140,248,.35);color:#c7d2fef2}.platform-summary-name{font-size:.9375rem;font-weight:700;color:#f8fafcf2}.platform-summary-tagline{font-size:.75rem;color:#94a3b8e6;margin-top:2px}.platform-summary-metrics{display:flex;flex:2 1 360px;align-items:center;flex-wrap:wrap;gap:var(--space-2) 0}.platform-summary-metric{flex:1 1 100px;min-width:88px;padding:0 var(--space-3);text-align:center}.platform-summary-metric-label{display:block;font-size:.6875rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#94a3b8d9;margin-bottom:4px}.platform-summary-metric-value{font-size:1.375rem;font-weight:700;color:#f8fafcfa;line-height:1.2}.platform-summary-divider{width:1px;align-self:stretch;min-height:36px;background:#ffffff1a;margin:0 var(--space-1)}.platform-summary-metric--health .platform-summary-metric-value{font-size:1rem}.platform-summary-health{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:1rem;font-weight:700}.platform-summary-health--healthy{color:#4ade80}.platform-summary-health--deploying{color:#fb923c}.platform-summary-health--attention{color:#f87171}.platform-card{display:flex;flex-direction:row;cursor:pointer;transition:all var(--transition-slow);position:relative;overflow:hidden;padding:0;height:250px}.platform-card.glass-card{background:#2c353d;border:1px solid rgba(255,255,255,.08);box-shadow:0 4px 24px #00000059}.platform-card:hover{transform:translateY(-3px);box-shadow:0 8px 32px #0006,0 0 0 1px #7000ff40}.platform-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient-primary);opacity:0;transition:opacity var(--transition-base);z-index:2}.platform-card:hover:before{opacity:1}.platform-card-illustration{position:relative;width:40%;margin:20px 0;min-width:140px;background:url(/platform-card.svg) center center / cover no-repeat;border-radius:var(--radius-xl) 0 0 var(--radius-xl);overflow:hidden;flex-shrink:0}.platform-card-illustration svg{display:none}.platform-card-content{flex:1;display:flex;flex-direction:column;justify-content:space-between;padding:var(--space-4) var(--space-5);min-width:0;position:relative;overflow:hidden}.platform-card-content .app-menu-container{position:absolute;top:8px;right:8px;z-index:10}.platform-card-name{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0}.platform-card-name-with-tag{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.platform-card-name-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.platform-menu-btn{opacity:0;transform:scale(.8)}.platform-card:hover .platform-menu-btn{opacity:1;transform:scale(1)}.platform-card-org{display:flex;align-items:center;gap:5px;font-size:.8125rem;color:var(--text-tertiary)}.platform-card-avatar{width:48px;height:48px;background:var(--gradient-primary);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;color:#fff;box-shadow:0 4px 14px #7000ff73;flex-shrink:0}.platform-card-meta-row{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-2)}.platform-app-count{display:flex;align-items:center;gap:var(--space-2);font-size:.75rem;color:#fff;padding:5px 12px;background:var(--bg-tertiary);border-radius:56px;width:fit-content;flex:0 0 auto;line-height:1}.platform-stack-tags{display:flex;flex-wrap:wrap;gap:5px;flex:0 0 auto}.platform-stack-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:500;white-space:nowrap}.platform-stack-tag.platform-stack-tag-unified{background:#a855f71f;color:#7000ff;border-radius:56px;padding:5px 12px;width:fit-content;display:flex;align-items:center;gap:10px;max-width:100%;overflow:hidden;text-overflow:ellipsis;min-width:0;line-height:1}.platform-stack-item{display:inline-flex;align-items:center;gap:4px;flex:0 0 auto}.platform-stack-icon{width:16px;height:16px;flex:0 0 auto}.platform-stack-more{margin-left:auto;flex:0 0 auto;color:#7000ff;opacity:.85}.platform-stack-tag.type-frontend{background:#f59e0b1f;color:#f59e0b}.platform-stack-tag.type-ecs{background:#6366f11f;color:#818cf8}.platform-stack-tag.type-serverless{background:#10b9811f;color:#34d399}.platform-stack-tag.type-rds{background:#8b5cf61f;color:#a78bfa}.platform-stack-tag.type-mongodb{background:#22c55e1f;color:#4ade80}.platform-stack-tag.type-redis{background:#ef44441f;color:#f87171}.platform-stack-tag.type-more{background:var(--bg-tertiary);color:var(--text-tertiary)}.platform-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:var(--space-3);border-top:1px solid rgba(255,255,255,.07)}.platform-card-date{display:inline-flex;align-items:center;font-size:.75rem;font-weight:500;color:#7000ff;padding:5px 12px;background:#a855f71f;border-radius:56px;width:fit-content;line-height:1}.platform-env-tag{font-size:.7rem;font-weight:900;letter-spacing:.06em;padding:3px 8px;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:#ffffffd9;flex:0 0 auto}.platform-env-tag-development{border-color:#6366f16b;background:#6366f129;color:#e3e9fff2}.platform-env-tag-staging{border-color:#f59e0b6b;background:#f59e0b29;color:#fff0d6f2}.platform-env-tag-production{border-color:#22c55e6b;background:#22c55e29;color:#dcffecf2}.platform-env-health{display:inline-flex;align-items:center;gap:8px;margin-top:8px;padding:4px 8px;border-radius:999px;font-size:.72rem;font-weight:800;border:1px solid rgba(255,255,255,.1);background:#ffffff08;color:#ffffffd9;width:fit-content}.platform-env-dot{width:8px;height:8px;border-radius:999px;background:#94a3b899}.platform-env-dot-healthy{background:#22c55ef2}.platform-env-dot-deploying{background:#f59e0bf2}.platform-env-dot-attention{background:#ef4444f2}.platform-env-dot-empty,.platform-env-dot-loading{background:#94a3b8a6}.platform-env-meta{margin-top:6px;font-size:.7rem;color:#ffffff8c;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-card{display:flex;flex-direction:column;padding:var(--space-5);cursor:pointer;transition:all var(--transition-slow);position:relative;overflow:hidden}.app-card:hover{transform:translateY(-4px)}.app-card:hover .app-menu{opacity:1;transform:scale(1)}.app-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient-primary);opacity:0;transition:opacity var(--transition-base)}.app-card:hover:before{opacity:.5}.app-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.app-avatar{width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);border-radius:var(--radius-xl);font-size:1.375rem;font-weight:700;color:#fff;box-shadow:0 4px 14px #6366f14d;position:relative;overflow:hidden}.app-avatar:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.2) 0%,transparent 100%)}.app-menu{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);color:var(--text-tertiary);opacity:0;transform:scale(.8);transition:all var(--transition-fast);background:var(--bg-elevated)}.app-menu:hover{background:var(--bg-hover);color:var(--text-primary)}.app-card-body{margin-bottom:var(--space-3)}.app-name{font-size:1rem;font-weight:600;margin-bottom:var(--space-1)}.app-slug{font-size:.8125rem;color:var(--text-tertiary)}.app-card-meta{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.app-repo{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:.75rem;color:var(--text-secondary)}.app-framework{padding:var(--space-1) var(--space-2);background:#3b82f61a;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:500;color:var(--accent-primary)}.app-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:var(--space-3);border-top:1px solid var(--border-color);margin-top:auto}.app-status{display:flex;align-items:center;gap:var(--space-2);font-size:.8125rem;color:var(--text-secondary)}.status-building-sm{width:14px;height:14px;border:2px solid var(--accent-warning);border-top-color:transparent;border-radius:50%;animation:spin 1s linear infinite}.app-link{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-tertiary);transition:all var(--transition-fast)}.app-link:hover{background:var(--bg-hover);color:var(--accent-primary)}.platform-pipeline-skeleton .platform-env-cards-row{gap:var(--space-4)}.platform-env-card-skeleton{flex:1 1 0;min-width:120px;min-height:300px;border-radius:28px;padding:0;animation:fadeIn .3s ease-out}.platform-summary-bar-skeleton{height:96px;border-radius:22px;width:100%;animation:fadeIn .3s ease-out}.platform-skeleton-card{display:flex;flex-direction:row;padding:0;height:190px;overflow:hidden}.skeleton-avatar{width:52px;height:52px;border-radius:var(--radius-xl)}.apps-search{position:relative;width:320px}.apps-search .search-icon{position:absolute;left:var(--space-4);top:50%;transform:translateY(-50%);color:var(--text-muted);transition:color var(--transition-fast)}.apps-search:focus-within .search-icon{color:var(--accent-primary)}.apps-search .input{padding-left:var(--space-10);border-radius:var(--radius-xl);background:var(--bg-secondary);border-color:var(--border-color);font-weight:500}.apps-search .input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-light)}@media (max-width: 1100px){.platform-env-cards-row{flex-wrap:wrap;justify-content:center;gap:var(--space-4)}.platform-env-connector{display:none}.platform-env-card{flex:1 1 calc(50% - var(--space-4));min-width:240px}}@media (max-width: 1024px){.platform-grid{grid-template-columns:1fr}.apps-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.apps-header{flex-direction:column;align-items:stretch}.apps-actions{flex-wrap:wrap}.apps-search{width:100%}.platform-grid{grid-template-columns:1fr}.platform-env-highlight{grid-column:auto;padding:var(--space-4) var(--space-3)}.platform-env-card{flex:1 1 100%;min-height:0}.platform-summary-metrics{flex-direction:column;width:100%}.platform-summary-divider{display:none}.platform-summary-metric{text-align:left;padding:var(--space-2) 0;border-bottom:1px solid rgba(255,255,255,.06)}.platform-summary-metric:last-child{border-bottom:none}.apps-grid{grid-template-columns:1fr}}.app-menu-container{position:relative}.app-dropdown{position:absolute;top:100%;right:0;margin-top:var(--space-1);min-width:160px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:0 10px 40px #0006;padding:var(--space-2);z-index:100;animation:dropdownFadeIn .15s ease-out}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-2) var(--space-3);font-size:.8125rem;color:var(--text-secondary);border-radius:var(--radius-md);transition:all var(--transition-fast);text-align:left}.dropdown-item:hover{background:var(--bg-elevated);color:var(--text-primary)}.dropdown-item-danger{color:var(--accent-error)}.dropdown-item-danger:hover{background:#ef44441a;color:var(--accent-error)}.dropdown-divider{height:1px;background:var(--border-color);margin:var(--space-2) 0}.modal{width:100%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out}.platform-resource-list{display:flex;flex-direction:column;gap:4px;flex:1;min-height:0;overflow:hidden}.platform-resource-row{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--text-secondary);min-width:0}.platform-resource-icon{flex-shrink:0;color:var(--text-tertiary)}.platform-resource-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.platform-resource-more{font-size:.6875rem;color:var(--text-muted);font-style:italic}.new-app-page{max-width:720px;margin:0 auto}.new-app-header{margin-bottom:var(--space-8)}.back-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);margin-bottom:var(--space-4);color:var(--text-secondary);font-size:.875rem;border-radius:var(--radius-md);transition:all var(--transition-fast)}.new-app-header h1{font-size:1.75rem;font-weight:700;margin-bottom:var(--space-2)}.new-app-subtitle{color:var(--text-secondary)}.progress-steps{display:flex;align-items:center;justify-content:center;gap:var(--space-3);margin-bottom:var(--space-8)}.progress-step{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-size:.875rem;color:var(--text-muted);transition:all var(--transition-base)}.progress-step.active{background:var(--bg-elevated);color:var(--text-primary)}.progress-step.completed{color:var(--accent-success)}.step-number{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.progress-step.active .step-number{background:var(--gradient-primary);color:#fff}.progress-step.completed .step-number{background:var(--accent-success);color:#fff}.step-line{width:40px;height:2px;background:var(--border-color)}.error-banner{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-lg);color:var(--accent-error);margin-bottom:var(--space-6)}.form-card{padding:var(--space-6)}.form-section{margin-bottom:var(--space-6)}.form-section h3{display:flex;align-items:center;gap:var(--space-2);font-size:1rem;font-weight:600;margin-bottom:var(--space-5);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-color)}.input-with-icon-wrapper{position:relative}.input-prefix-icon{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);color:var(--text-muted)}.input-with-prefix{padding-left:var(--space-10)}.mono{font-family:var(--font-mono)}.subdomain-input-wrapper{display:flex;align-items:stretch;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-tertiary);border:1px solid var(--border-color);transition:all var(--transition-fast)}.subdomain-input-wrapper:focus-within{border-color:var(--accent-primary);box-shadow:0 0 0 3px #3b82f633}.subdomain-input-wrapper .subdomain-input{flex:1;border:none;background:transparent;border-radius:0}.subdomain-input-wrapper .subdomain-input:focus{box-shadow:none}.subdomain-suffix{display:flex;align-items:center;padding:0 var(--space-4);background:var(--bg-elevated);color:var(--text-muted);font-size:.875rem;font-family:var(--font-mono);border-left:1px solid var(--border-color);white-space:nowrap}.input-hint.success{color:var(--accent-success)}.input-hint strong{font-family:var(--font-mono);font-size:.8125rem}.framework-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3)}.framework-option{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-4);background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.framework-option:hover{background:var(--bg-elevated);border-color:var(--border-light)}.framework-option.selected{background:#3b82f61a;border-color:var(--accent-primary)}.framework-icon{font-size:1.5rem}.framework-name{font-size:.8125rem;font-weight:500}.backend-type-toggle{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.type-option{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:left;color:var(--text-secondary)}.type-option:hover{background:var(--bg-elevated);border-color:var(--border-light);color:var(--text-primary)}.type-option.active{background:#3b82f61a;border-color:var(--accent-primary);color:var(--text-primary)}.type-option.active svg{color:var(--accent-primary)}.type-option-text{display:flex;flex-direction:column;gap:2px}.type-option-title{font-size:.875rem;font-weight:600}.type-option-desc{font-size:.75rem;color:var(--text-muted)}.form-actions{display:flex;justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-6);border-top:1px solid var(--border-color)}.creating-step{display:flex;justify-content:center}.creating-card{text-align:center;padding:var(--space-12);min-width:400px}.creating-progress,.creating-success{display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.creating-progress svg{color:var(--accent-primary)}.creating-success .success-icon{color:var(--accent-success)}.creating-card h3{font-size:1.25rem;font-weight:600}.creating-card p{color:var(--text-secondary)}@media (max-width: 640px){.framework-grid{grid-template-columns:repeat(2,1fr)}.progress-steps{flex-wrap:wrap}.step-line{display:none}}.github-selector{display:flex;flex-direction:column;height:100%;max-height:600px;background:var(--card-bg);border-radius:12px;overflow:hidden}.github-selector-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.1)}.github-selector-header h3{display:flex;align-items:center;gap:.5rem;margin:0;font-size:1rem;font-weight:600}.header-actions{display:flex;align-items:center;gap:.5rem}.github-search{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.1);background:#0003}.github-search input{flex:1;background:transparent;border:none;outline:none;color:var(--text-primary);font-size:.875rem}.github-search input::placeholder{color:var(--text-muted)}.github-error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:#ef44441a;color:#ef4444;font-size:.875rem}.github-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem;color:var(--text-muted)}.github-not-connected{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem;text-align:center}.github-not-connected h4{margin:0;font-size:1.125rem}.github-not-connected p{margin:0;color:var(--text-muted);font-size:.875rem}.github-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.github-repos-list{flex:1;overflow-y:auto;padding:.5rem}.github-empty{display:flex;align-items:center;justify-content:center;padding:2rem;color:var(--text-muted)}.github-repo-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 1rem;border-radius:8px;cursor:pointer;transition:all .2s ease}.github-repo-item:hover{background:#ffffff0d}.github-repo-item.selected{background:#6366f126;border:1px solid rgba(99,102,241,.3)}.repo-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.repo-info{flex:1;min-width:0}.repo-name{font-weight:500;font-size:.875rem;color:var(--text-primary);margin-bottom:.25rem}.repo-description{font-size:.75rem;color:var(--text-muted);margin-bottom:.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.repo-meta{display:flex;align-items:center;gap:1rem;font-size:.75rem;color:var(--text-muted)}.repo-language{display:flex;align-items:center;gap:.25rem}.language-dot{width:8px;height:8px;border-radius:50%}.repo-stars{display:flex;align-items:center;gap:.25rem}.repo-updated{color:var(--text-muted)}.github-branch-section{padding:1rem 1.25rem;border-top:1px solid rgba(255,255,255,.1);background:#0003}.branch-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.875rem;font-weight:500}.branch-loading{display:flex;align-items:center;justify-content:center;padding:.5rem}.branch-select{width:100%;padding:.625rem .75rem;background:var(--input-bg);border:1px solid var(--input-border);border-radius:6px;color:var(--text-primary);font-size:.875rem;cursor:pointer}.branch-select:focus{outline:none;border-color:var(--primary)}.detected-framework{display:flex;align-items:center;gap:.5rem;margin-top:.75rem;padding:.5rem .75rem;background:#22c55e1a;border-radius:6px;font-size:.75rem}.framework-label{color:#22c55e;font-weight:500}.framework-value{color:var(--text-muted);font-family:monospace}.github-selector-footer{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;padding:1rem 1.25rem;border-top:1px solid rgba(255,255,255,.1);background:#0003}.github-selector-modal{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;padding:2rem}.github-selector-modal .github-selector{width:100%;max-width:600px;max-height:80vh;box-shadow:0 25px 50px -12px #00000080}.app-detail{max-width:1400px}.app-detail-switching{opacity:.45;pointer-events:none;transition:opacity .15s ease}.app-detail-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap}.back-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);color:var(--text-secondary);font-size:.875rem;border-radius:var(--radius-md);transition:all var(--transition-fast)}.back-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.app-title-section{display:flex;align-items:center;gap:var(--space-4);flex:1}.app-avatar-lg{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);border-radius:var(--radius-lg);font-size:1.5rem;font-weight:700;color:#fff}.app-avatar-lg.app-avatar-3d{background:transparent;border:none;border-radius:var(--radius-lg);overflow:hidden;padding:2px;box-sizing:border-box}.app-avatar-icon{width:100%;height:100%;object-fit:contain;display:block}.app-title-info h1{font-size:1.5rem;font-weight:700;margin-bottom:var(--space-1)}.app-meta{display:flex;align-items:center;gap:var(--space-3)}.app-slug{color:var(--text-tertiary);font-size:.875rem}.app-repo-link{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:.75rem;color:var(--text-secondary);transition:all var(--transition-fast)}.app-repo-link:hover{background:var(--bg-elevated);color:var(--accent-primary)}.app-actions{display:flex;align-items:center;gap:var(--space-2)}.ws-status{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);font-size:.75rem;font-weight:500;border-radius:var(--radius-sm)}.ws-connected{background:#34d39926;color:var(--accent-success)}.ws-disconnected{background:#9ca3af26;color:var(--text-muted)}.error-banner{padding:var(--space-3) var(--space-4);background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-lg);color:var(--accent-error);margin-bottom:var(--space-6)}.info-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}.info-card{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2)}.info-label{font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.info-value{font-size:.9375rem;font-weight:500}.url-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}.url-card{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2);transition:all var(--transition-fast)}.url-card:hover{border-color:var(--accent-primary)}.url-label{font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.url-value{display:flex;align-items:center;gap:var(--space-2);font-size:.875rem;color:var(--accent-primary);word-break:break-all}.deployments-section{margin-top:var(--space-8)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.section-header h3{font-size:1.125rem;font-weight:600}.deployment-count{font-size:.8125rem;color:var(--text-tertiary)}.empty-deployments{padding:var(--space-12);display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-3)}.empty-icon{color:var(--text-muted);margin-bottom:var(--space-2)}.empty-deployments h4{font-size:1rem;font-weight:600}.empty-deployments p{color:var(--text-secondary);margin-bottom:var(--space-4)}.deployments-table{padding:0;overflow:hidden}.deployment-row{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);border-bottom:1px solid var(--border-color);transition:background var(--transition-fast)}.deployment-row:last-child{border-bottom:none}.deployment-row:hover{background:var(--bg-elevated)}.deployment-status-icon{min-width:90px;display:flex;align-items:center;justify-content:flex-start}.deployment-details{flex:1;min-width:0}.deployment-main{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-1)}.deployment-version{font-size:.8125rem;font-weight:600;color:var(--accent-primary)}.deployment-message{font-size:.875rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.deployment-meta-info{display:flex;align-items:center;gap:var(--space-2);font-size:.75rem;color:var(--text-tertiary)}.deployment-meta-info span{display:flex;align-items:center;gap:var(--space-1)}.deployment-date{color:var(--text-secondary);font-weight:500}.deployment-timeago{color:var(--text-tertiary)}.deployment-date+.deployment-timeago:before{content:"·";margin-right:var(--space-2)}.deployment-components{display:flex;align-items:center;gap:var(--space-2);margin-left:var(--space-2)}.component-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:12px;font-size:.6875rem;font-weight:500;text-transform:uppercase;letter-spacing:.02em}.component-frontend{background:#f0883e26;color:#f0883e;border:1px solid rgba(240,136,62,.3)}.component-backend{background:#a371f726;color:#a371f7;border:1px solid rgba(163,113,247,.3)}.component-unknown{background:#94a3b826;color:#94a3b8;border:1px solid rgba(148,163,184,.3)}.deployment-menu{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--text-tertiary);opacity:0;transition:all var(--transition-fast)}.deployment-row:hover .deployment-menu{opacity:1}.deployment-menu:hover{background:var(--bg-hover);color:var(--text-primary)}.deployment-actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0;flex-wrap:wrap;justify-content:flex-end}.view-logs-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:.8125rem;font-weight:500;color:var(--text-secondary);border-radius:var(--radius-md);transition:all var(--transition-fast)}.view-logs-btn:hover{background:var(--bg-elevated);color:var(--accent-primary)}.view-logs-btn svg{color:var(--accent-primary)}.status-success{color:var(--accent-success)}.status-error{color:var(--accent-error)}.status-warning{color:var(--accent-warning)}.status-pending{color:var(--text-muted)}.loading-center{display:flex;align-items:center;justify-content:center;min-height:300px;color:var(--accent-primary)}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:var(--space-4)}@media (max-width: 768px){.info-cards{grid-template-columns:repeat(2,1fr)}.url-cards{grid-template-columns:1fr}.app-detail-header{flex-direction:column;align-items:flex-start}.app-actions{width:100%;justify-content:flex-end}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-4);animation:fadeIn .2s ease-out}.modal{width:100%;max-width:500px;max-height:90vh;margin-top:10px;display:flex;flex-direction:column;animation:slideUp .3s ease-out;background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5);border-bottom:1px solid var(--border-color);flex-shrink:0}.modal-body{padding:var(--space-5);overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-5);border-top:1px solid var(--border-color);flex-shrink:0}.input-label{display:block;font-size:.8125rem;font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-2)}.input{width:100%;padding:var(--space-3);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;transition:all var(--transition-fast)}select.input{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}.input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #6366f133}.input.mono{font-family:SF Mono,Monaco,Inconsolata,monospace}.danger-zone{margin-top:var(--space-6);padding:var(--space-4);border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-lg);background:#ef44440d}.danger-zone h4{font-size:.875rem;font-weight:600;color:var(--accent-error);margin-bottom:var(--space-2)}.danger-zone p{font-size:.8125rem;color:var(--text-secondary);margin-bottom:var(--space-4)}.btn-danger:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-1px)}.btn-danger:disabled{opacity:.6;transform:none}.checkbox-group{display:flex;flex-direction:column;gap:12px;margin-top:16px;padding:16px;background:#ffffff08;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.checkbox-item{display:flex;align-items:center;gap:10px;cursor:pointer;padding:8px;border-radius:6px;transition:background .2s}.checkbox-item:hover{background:#ffffff0d}.checkbox-item input[type=checkbox]{width:18px;height:18px;border-radius:4px;background:#0000004d;border:1px solid rgba(255,255,255,.2);cursor:pointer;accent-color:var(--primary-color)}.checkbox-item span{color:var(--text-primary);font-size:.95rem}.text-error{color:#ef4444}.text-sm{font-size:.875rem}.mt-2{margin-top:.5rem}.logs-section{margin-bottom:var(--space-6);padding:0;overflow:hidden}.logs-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--bg-elevated);border-bottom:1px solid var(--border-color)}.logs-header h3{display:flex;align-items:center;gap:var(--space-2);font-size:.9375rem;font-weight:600;flex:1;margin:0}.logs-title-row{display:flex;align-items:center;justify-content:space-between;width:100%;margin-bottom:var(--space-2)}.logs-deployment-version{font-size:.75rem;font-weight:500;color:var(--accent-primary);background:#6366f126;padding:2px 8px;border-radius:12px;border:1px solid rgba(99,102,241,.3);margin-left:var(--space-2)}.logs-live-indicator{display:inline-flex;align-items:center;gap:6px;font-size:.75rem;font-weight:600;color:var(--accent-success);background:#34d39926;padding:4px 10px;border-radius:12px;border:1px solid rgba(52,211,153,.3);animation:fadeIn .3s ease-out}.live-dot{width:8px;height:8px;background:var(--accent-success);border-radius:50%;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.logs-container{background:#0d1117;padding:var(--space-4);max-height:600px;overflow-y:auto;font-family:var(--font-mono);font-size:.8125rem;line-height:1.6}.logs-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-8);color:var(--text-muted)}.log-line{display:flex;gap:var(--space-3);padding:3px 0;color:#c9d1d9;font-size:.8125rem;line-height:1.5;border-left:3px solid transparent;padding-left:var(--space-2);margin-left:calc(-1 * var(--space-2));transition:background-color .15s ease}.log-line:hover{background-color:#ffffff08}.log-line.frontend{border-left-color:#f0883e}.log-line.backend{border-left-color:#a371f7}.log-line-num{color:#484f58;flex-shrink:0;min-width:36px;text-align:right;font-family:var(--font-mono);font-size:.75rem;-webkit-user-select:none;user-select:none}.log-time{color:#6e7681;flex-shrink:0;min-width:70px;font-family:var(--font-mono);font-size:.75rem}.log-component{flex-shrink:0;min-width:70px;font-weight:600;font-size:.6875rem;text-transform:uppercase;letter-spacing:.05em;padding:1px 6px;border-radius:3px;background:#58a6ff26;color:#58a6ff}.log-component-frontend{background:#f0883e26;color:#f0883e}.log-component-backend{background:#a371f726;color:#a371f7}.log-message{color:#c9d1d9;word-break:break-word;flex:1}@keyframes logEntry{0%{opacity:0;transform:translateY(-2px)}to{opacity:1;transform:translateY(0)}}.log-line{animation:logEntry .2s ease-out}.frontend-url-banner{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5);margin-bottom:var(--space-6);background:linear-gradient(135deg,#34d3991a,#10b9811a);border:1px solid rgba(52,211,153,.3)}.frontend-url-banner svg{color:var(--accent-success);flex-shrink:0}.frontend-url-info{display:flex;flex-direction:column;gap:var(--space-1)}.frontend-url-label{font-size:.8125rem;color:var(--accent-success);font-weight:500}.frontend-url-link{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-mono);font-size:.9375rem;color:var(--text-primary)}.frontend-url-link:hover{color:var(--accent-success)}.btn-sm{padding:var(--space-2) var(--space-3);font-size:.8125rem}.config-grid{display:grid;grid-template-columns:1fr;gap:var(--space-4);margin-bottom:var(--space-6)}.config-card{display:flex;flex-direction:column;height:100%;transition:transform .2s,box-shadow .2s}.config-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px #0003}.config-card-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);border-bottom:1px solid var(--border-color)}.config-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border-radius:var(--radius-md);color:var(--text-primary);padding:2px;box-sizing:border-box}.config-icon-img{width:100%;height:100%;object-fit:contain;display:block}.config-card-header h3{font-size:1rem;font-weight:600;flex:1}.config-card-body{padding:var(--space-4);flex:1;display:flex;flex-direction:column;gap:var(--space-3)}.config-item{display:flex;align-items:center;gap:var(--space-2);color:var(--text-secondary);font-size:.875rem}.config-item svg{color:var(--text-tertiary)}.config-link{display:flex;align-items:center;gap:var(--space-1);color:var(--accent-primary);font-size:.875rem;margin-top:var(--space-2)}.config-link:hover{text-decoration:underline}.database-details{padding:var(--space-4);border-top:1px solid var(--border-color)}.database-info-row{display:flex;flex-direction:column;gap:var(--space-3)}.info-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) 0}.info-icon{color:var(--text-tertiary);flex-shrink:0;width:16px;height:16px}.info-value{color:var(--text-primary);font-size:.9375rem;font-weight:500}.config-url-wrapper{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-2)}.url-info-tooltip{display:flex;align-items:center;color:var(--text-tertiary);cursor:help;transition:color var(--transition-fast)}.url-info-tooltip:hover{color:var(--accent-primary)}.config-placeholder{color:var(--text-tertiary);font-size:.875rem;font-style:italic;text-align:center;margin:auto 0}.config-card-footer{padding:var(--space-4);border-top:1px solid var(--border-color);display:flex;justify-content:space-between;gap:var(--space-2)}.deploy-options{display:flex;flex-direction:column;gap:var(--space-3)}.checkbox-label{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg-tertiary);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.checkbox-label:hover:not(:has(:disabled)){background:var(--bg-elevated)}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent-primary)}.warning-text{color:var(--accent-warning);font-size:.875rem;margin-top:var(--space-2);text-align:center}.envvars-section{margin-top:var(--space-4);border-top:1px solid var(--border-color);padding-top:var(--space-4)}.envvars-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;padding:var(--space-2) var(--space-3);background:var(--bg-tertiary);border-radius:var(--radius-md);font-size:.875rem;color:var(--text-secondary);transition:all var(--transition-fast)}.envvars-header:hover{background:var(--bg-elevated);color:var(--text-primary)}.envvars-content{padding-top:var(--space-3)}.envvars-hint{display:flex;flex-direction:column;gap:var(--space-1);font-size:.75rem;color:var(--text-muted);margin-bottom:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--bg-tertiary);border-radius:var(--radius-sm)}.envvars-hint-row{display:flex;align-items:center;gap:var(--space-2)}.envvars-hint code{background:var(--bg-elevated);padding:.125rem .375rem;border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:.7rem;color:var(--accent-primary)}.envvar-row{display:flex;gap:var(--space-2);margin-bottom:var(--space-2);align-items:center}.envvar-row input{flex:1}.envvar-row input:first-child{flex:.4;font-family:var(--font-mono);font-size:.8125rem}.btn-icon{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;flex-shrink:0}.btn-danger-outline{border:1px solid rgba(239,68,68,.3);color:var(--accent-error);background:transparent}.btn-danger-outline:hover{background:#ef44441a;border-color:var(--accent-error)}.card-actions{display:flex;justify-content:flex-end;padding-top:var(--space-3);margin-top:var(--space-4);border-top:1px solid var(--border-color)}.btn-error{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:.8125rem;font-weight:500;border-radius:var(--radius-md);border:1px solid rgba(239,68,68,.4);background:#ef44441a;color:var(--accent-error);transition:all var(--transition-fast);cursor:pointer}.btn-error:hover:not(:disabled){background:#ef444433;border-color:var(--accent-error);transform:translateY(-1px)}.btn-error:disabled{opacity:.5;cursor:not-allowed}.btn-error svg{width:14px;height:14px}.compute-panel{display:flex;flex-direction:column;gap:var(--space-6);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border-color)}.compute-section{display:flex;flex-direction:column;gap:var(--space-3)}.compute-section-title{display:flex;align-items:center;gap:var(--space-2);font-size:.8125rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.compute-presets{display:flex;flex-wrap:wrap;gap:var(--space-2)}.compute-preset-btn{display:flex;flex-direction:column;align-items:center;padding:var(--space-2) var(--space-3);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.8125rem;cursor:pointer;transition:all var(--transition-fast);min-width:72px}.compute-preset-btn:hover{border-color:var(--accent-primary);color:var(--text-primary)}.compute-preset-btn.active{border-color:var(--accent-primary);background:#6366f11f;color:var(--accent-primary)}.preset-label{font-weight:600;font-size:.8125rem}.preset-detail{font-size:.7rem;color:var(--text-muted);margin-top:2px}.compute-preset-btn.active .preset-detail{color:var(--accent-primary);opacity:.8}.compute-row{display:flex;gap:var(--space-3);flex-wrap:wrap}.compute-row .input-group{flex:1;min-width:120px}.compute-hint{font-size:.75rem;color:var(--text-muted);line-height:1.5;margin:0}.multi-select-filter{position:relative;min-width:180px}.multi-select-trigger{display:flex;align-items:center;gap:var(--space-2);width:100%;min-height:38px;padding:var(--space-2) var(--space-3);border-radius:var(--radius-xl);border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-size:.8125rem;cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.multi-select-trigger:hover:not(:disabled){border-color:var(--text-muted)}.multi-select-trigger.open,.multi-select-trigger:focus-visible{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-light);outline:none}.multi-select-trigger.has-selection{border-color:var(--accent-primary)}.multi-select-trigger:disabled{opacity:.55;cursor:not-allowed}.multi-select-trigger-label{font-weight:600;color:var(--text-secondary);white-space:nowrap}.multi-select-trigger-value{flex:1;min-width:0;text-align:left;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.multi-select-chevron{flex-shrink:0;color:var(--text-muted);transition:transform var(--transition-fast)}.multi-select-chevron.open{transform:rotate(180deg)}.multi-select-clear{display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:2px;border-radius:var(--radius-sm);color:var(--text-muted)}.multi-select-clear:hover{color:var(--accent-primary);background:var(--bg-hover)}.multi-select-menu{position:absolute;top:calc(100% + 6px);left:0;z-index:50;min-width:100%;max-width:320px;max-height:280px;display:flex;flex-direction:column;border-radius:var(--radius-lg);border:1px solid var(--border-color);background:var(--bg-primary);box-shadow:var(--shadow-lg, 0 12px 40px rgba(0, 0, 0, .18));animation:multiSelectFadeIn .15s ease-out}@keyframes multiSelectFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.multi-select-menu-actions{display:flex;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border-color)}.multi-select-menu-action{font-size:.75rem;font-weight:500;color:var(--accent-primary);background:none;border:none;padding:0;cursor:pointer}.multi-select-menu-action:hover{text-decoration:underline}.multi-select-options{list-style:none;margin:0;padding:var(--space-2);overflow-y:auto}.multi-select-options li+li{margin-top:2px}.multi-select-option{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-2);border-radius:var(--radius-md);cursor:pointer;font-size:.8125rem;color:var(--text-primary)}.multi-select-option:hover{background:var(--bg-hover)}.multi-select-option input[type=checkbox]{margin-top:2px;flex-shrink:0;accent-color:var(--accent-primary)}.multi-select-option span{line-height:1.35;word-break:break-word}.billing-page{padding:var(--space-2) 0;max-width:1400px}.billing-loading,.billing-error,.billing-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:280px;gap:var(--space-3);color:var(--text-secondary);font-size:.875rem}.billing-spinner{animation:billing-spin 1s linear infinite;color:var(--accent-primary)}@keyframes billing-spin{to{transform:rotate(360deg)}}.billing-page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-5);gap:var(--space-4);flex-wrap:wrap}.billing-page-title-block{display:flex;align-items:center;gap:var(--space-3)}.billing-page-icon{color:var(--accent-primary);flex-shrink:0}.billing-page-title{font-size:1.4rem;font-weight:700;color:var(--text-primary);margin:0;line-height:1.2}.billing-page-subtitle{font-size:.78rem;color:var(--text-tertiary);margin:2px 0 0}.billing-tab-bar{display:flex;gap:2px;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:8px;padding:3px}.billing-tab{display:flex;align-items:center;gap:5px;padding:5px 16px;font-size:.82rem;font-weight:500;border:none;border-radius:5px;background:transparent;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s}.billing-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.billing-tab-active{background:var(--bg-primary)!important;color:var(--text-primary)!important;border:1px solid var(--border-color)}.billing-tab-icon{font-style:normal;font-size:.9rem}.billing-year-selector{position:relative;display:inline-flex;align-items:center}.billing-year-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:.8rem;padding:5px 30px 5px 10px;cursor:pointer}.billing-year-select:focus{outline:none;border-color:var(--accent-primary)}.billing-year-icon{position:absolute;right:8px;pointer-events:none;color:var(--text-tertiary)}.billing-section-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 2px}.billing-section-subtitle{font-size:.76rem;color:var(--text-tertiary);margin:0}.billing-region-chip{display:inline-block;font-size:.67rem;font-weight:500;color:var(--text-muted);background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:4px;padding:2px 6px;white-space:nowrap;text-align:left}.billing-env-chip{display:inline-block;font-size:.62rem;font-weight:600;border-radius:4px;padding:2px 6px;white-space:nowrap;text-transform:uppercase;letter-spacing:.03em;text-align:left}.billing-env-dev{color:#60a5fa;background:#60a5fa1a;border:1px solid rgba(96,165,250,.25)}.billing-env-stage,.billing-env-stag{color:#f59e0b;background:#f59e0b1a;border:1px solid rgba(245,158,11,.25)}.billing-env-all{color:var(--text-secondary);background:var(--bg-tertiary);border:1px solid var(--border-subtle);text-transform:none;letter-spacing:0}.billing-env-prod{color:#f87171;background:#f871711a;border:1px solid rgba(248,113,113,.25)}.billing-status-dot{display:inline-block;width:7px;height:7px;border-radius:50%;flex-shrink:0}.billing-dot-active{background:var(--accent-success);box-shadow:0 0 0 2px #22c55e33}.billing-dot-deploying{background:var(--accent-warning);box-shadow:0 0 0 2px #f59e0b33}.billing-dot-inactive{background:var(--text-muted)}.badge-secondary{background:var(--bg-elevated);border:1px solid var(--border-color);color:var(--text-secondary);padding:2px 8px;border-radius:4px;font-size:.72rem}.billing-filters-toolbar{margin-bottom:var(--space-4);display:flex;justify-content:flex-end}.billing-filters-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:var(--space-3);margin-left:auto}.billing-filters-row .multi-select-filter{width:200px}.billing-search-bar-toolbar{flex:0 1 auto;min-width:200px;max-width:320px}.billing-summary-table-grouped{min-width:820px}.billing-summary-table-grouped .billing-th-env,.billing-summary-table-grouped .billing-td-env{text-align:left!important;width:110px;min-width:110px;max-width:130px;padding-left:var(--space-3);padding-right:var(--space-2);position:sticky;left:0;background:var(--bg-secondary);z-index:1}.billing-summary-table-grouped .billing-td-env .billing-env-cell,.billing-summary-table-grouped .billing-td-env .billing-env-chip,.billing-summary-table-grouped .billing-td-env .external-notice-chip{justify-content:flex-start;text-align:left;margin-left:0;margin-right:auto}.billing-summary-table-grouped thead .billing-th-env{background:var(--bg-elevated);z-index:2}.billing-platform-group-header-row td{padding:0!important;border-bottom:1px solid var(--border-color)}.billing-platform-group-header-cell{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding:4px var(--space-3);min-height:28px;background:var(--bg-tertiary);text-align:left!important}.billing-platform-group-name{font-size:.78rem;font-weight:600;color:var(--text-primary);padding-left:var(--space-2);max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:help}.billing-platform-group-count{font-size:.68rem;font-weight:500;color:var(--text-tertiary);white-space:nowrap}.billing-summary-sub-row .billing-td-env{background:var(--bg-secondary)}.billing-summary-sub-row:hover .billing-td-env{background:var(--bg-hover)}.billing-env-cell{display:flex;align-items:flex-start;justify-content:flex-start;gap:4px;flex-wrap:wrap;padding-left:var(--space-2);width:100%;text-align:left}.billing-summary-table-grouped .billing-env-cell .billing-env-chip,.billing-summary-table-grouped .billing-env-cell .external-notice-chip{font-size:.58rem;padding:1px 5px}.billing-platform-sections{display:flex;flex-direction:column;gap:var(--space-5)}.billing-platform-sections-flow{flex-direction:row;flex-wrap:wrap;align-items:flex-start;gap:var(--space-4)}.billing-platform-section{border:1px solid var(--border-color);border-radius:12px;overflow:hidden;background:var(--bg-secondary)}.billing-platform-section-flow{--bp-card-w: 264px;--bp-card-h: 158px;--bp-card-gap: var(--space-3);--bp-row-pad: var(--space-3);width:calc((var(--card-count, 1) * var(--bp-card-w)) + (max(var(--card-count, 1) - 1,0) * var(--bp-card-gap)) + (2 * var(--bp-row-pad)) + 2px);max-width:100%;flex:0 0 auto}.billing-platform-section-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.billing-platform-section-title{margin:0;font-size:.85rem;font-weight:600;color:var(--text-primary);max-width:min(100%,var(--bp-card-w, 264px));overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.billing-platform-section-count{font-size:.7rem;font-weight:500;color:var(--text-tertiary);white-space:nowrap}.billing-platform-cards-row{display:flex;flex-wrap:wrap;gap:var(--space-3);padding:var(--space-3);align-items:stretch}.billing-platform-cards-row .billing-project-card{flex:0 0 var(--bp-card-w, 264px);width:var(--bp-card-w, 264px);min-width:var(--bp-card-w, 264px);max-width:var(--bp-card-w, 264px);height:var(--bp-card-h, 158px);min-height:var(--bp-card-h, 158px);max-height:var(--bp-card-h, 158px);box-sizing:border-box;overflow:hidden}.billing-project-card-compact{padding:var(--space-3);gap:6px;height:100%;min-height:0}.billing-platform-cards-row .billing-project-card-compact{display:flex;flex-direction:column}.billing-platform-cards-row .billing-project-card-compact .billing-card-header{flex-shrink:0}.billing-platform-cards-row .billing-project-card-compact .billing-card-badges{flex:1 1 auto;min-height:0;max-height:72px;overflow:hidden;align-content:flex-start;row-gap:4px}.billing-platform-cards-row .billing-project-card-compact .billing-card-cost-row{flex-shrink:0;margin-top:auto}.billing-project-card-compact .billing-card-badges{display:flex;flex-wrap:wrap;gap:4px;align-items:flex-start;justify-content:flex-start;text-align:left;width:100%}.billing-project-card-compact .billing-env-chip,.billing-project-card-compact .billing-region-chip,.billing-project-card-compact .billing-card-status-chip{font-size:.6rem;padding:1px 6px}.billing-card-status-chip{border-radius:4px;font-weight:600;white-space:nowrap;letter-spacing:.02em;text-align:left;justify-content:flex-start}.billing-card-cost-row{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-2);margin-top:2px;padding-top:6px;border-top:1px dashed var(--border-subtle)}.billing-card-cost-row .billing-card-cost-label{font-size:.68rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em}.billing-card-cost-row .billing-card-cost-value{font-size:.95rem;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums;white-space:nowrap}.billing-summary-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-4);gap:var(--space-3)}.billing-table-wrapper{overflow-x:auto;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-secondary)}.billing-summary-table,.billing-service-table{width:100%;border-collapse:collapse;font-size:.78rem;min-width:900px}.billing-summary-table th,.billing-service-table th{padding:9px 10px;text-align:right;font-weight:500;color:var(--text-tertiary);font-size:.73rem;border-bottom:1px solid var(--border-color);background:var(--bg-elevated);white-space:nowrap}.billing-th-project{text-align:left!important;min-width:200px;position:sticky;left:0;background:var(--bg-elevated);z-index:2}.billing-th-month{min-width:68px}.billing-th-current{color:var(--accent-primary)!important}.billing-th-total{min-width:100px;font-weight:600}.billing-summary-table td,.billing-service-table td{padding:7px 10px;text-align:right;border-bottom:1px solid var(--border-subtle);vertical-align:middle}.billing-td-project{text-align:left!important;position:sticky;left:0;background:var(--bg-secondary);z-index:1}.billing-td-month{font-variant-numeric:tabular-nums;white-space:nowrap}.billing-td-total{font-variant-numeric:tabular-nums;white-space:nowrap;font-weight:600;display:table-cell;vertical-align:middle}.billing-summary-row{cursor:pointer;transition:background .12s}.billing-summary-row:hover,.billing-summary-row:hover .billing-td-project{background:var(--bg-hover)}.billing-project-cell{display:flex;flex-direction:column;gap:4px}.billing-project-name{font-weight:500;color:var(--text-primary);line-height:1.2}.billing-project-meta{display:flex;align-items:center;gap:5px;flex-wrap:wrap}.billing-td-total{vertical-align:middle}.billing-total-actual,.billing-total-forecast{display:block;line-height:1.4}.billing-total-forecast{font-size:.72rem}.billing-grand{font-size:.88rem;font-weight:700}.billing-totals-row td{background:var(--bg-elevated)!important;border-top:2px solid var(--border-light)!important;font-weight:600}.billing-totals-row .billing-td-service,.billing-totals-row .billing-td-project,.billing-totals-row .billing-td-client,.billing-totals-row .billing-td-stack{background:var(--bg-elevated)!important}.billing-cell-actual{color:var(--accent-success)}.billing-cell-forecast{color:var(--accent-warning)}.billing-cell-total{color:var(--text-primary)}.billing-cell-empty{color:var(--text-muted)}.billing-legend{display:flex;align-items:center;gap:var(--space-4);margin-top:var(--space-3);font-size:.75rem;color:var(--text-secondary);flex-wrap:wrap}.billing-legend-overview{margin-bottom:var(--space-3);margin-top:0}.billing-legend-detail{margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--border-subtle)}.billing-legend-item{display:flex;align-items:center;gap:6px}.billing-legend-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}.billing-legend-actual{background:var(--accent-success)}.billing-legend-forecast{background:var(--accent-warning)}.billing-legend-divider{width:1px;height:14px;background:var(--border-color);margin:0 var(--space-1)}.billing-legend-hint{font-size:.72rem;color:var(--text-muted);font-style:italic}.billing-legend-stat{display:flex;align-items:center;gap:4px;color:var(--text-tertiary)}.billing-legend-stat strong{color:var(--text-secondary)}.billing-legend-user-count{display:flex;align-items:center;gap:4px;color:var(--accent-primary);font-size:.73rem}.billing-list-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-4);gap:var(--space-3);flex-wrap:wrap}.billing-list-controls{display:flex;align-items:center;gap:var(--space-2)}.billing-stat-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-3);margin-bottom:var(--space-4)}.billing-stat-card{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:10px;padding:var(--space-4)}.billing-stat-card-accent{border-color:#6366f14d;background:#6366f10a}.billing-stat-label{font-size:.72rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.billing-stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums;line-height:1;margin-bottom:4px}.billing-stat-sub{font-size:.72rem;color:var(--text-muted)}.billing-projects-section-label{font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-3)}.billing-search-bar{display:flex;align-items:center;gap:var(--space-2);background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:8px;padding:7px 12px;color:var(--text-tertiary)}.billing-search-bar input{flex:1;background:transparent;border:none;outline:none;font-size:.82rem;color:var(--text-primary);min-width:140px}.billing-search-bar input::placeholder{color:var(--text-muted)}.billing-project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--space-3)}.billing-project-card{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:10px;padding:var(--space-4);cursor:pointer;transition:border-color .15s,background .15s,transform .1s;display:flex;flex-direction:column;gap:var(--space-2)}.billing-project-card:hover{border-color:var(--border-light);background:var(--bg-hover);transform:translateY(-1px)}.billing-card-header{display:flex;justify-content:space-between;align-items:center;gap:var(--space-2)}.billing-card-name-row{display:flex;align-items:center;gap:8px;min-width:0}.billing-card-name{font-size:.9rem;font-weight:600;color:var(--text-primary);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.billing-card-arrow{color:var(--text-muted);flex-shrink:0;transition:color .12s,transform .12s}.billing-project-card:hover .billing-card-arrow{color:var(--accent-primary);transform:translate(2px)}.billing-card-badges{display:flex;gap:var(--space-2);flex-wrap:wrap;align-items:flex-start;justify-content:flex-start;text-align:left;width:100%}.billing-card-badges .billing-env-chip,.billing-card-badges .billing-region-chip,.billing-card-badges .billing-card-status-chip,.billing-card-badges .external-notice-chip{align-self:flex-start;text-align:left}.billing-card-cost-block{margin-top:auto;padding-top:var(--space-2);border-top:1px solid var(--border-subtle)}.billing-card-cost-label{font-size:.67rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px}.billing-card-cost-value{font-size:1.05rem;font-weight:700;color:var(--accent-success);font-variant-numeric:tabular-nums;display:flex;align-items:baseline;gap:2px}.billing-card-per-mo{font-size:.72rem;font-weight:500;color:var(--text-muted)}.billing-card-status-row{display:flex;align-items:center;gap:var(--space-2)}.billing-card-link{font-size:.75rem;color:var(--accent-primary)}.billing-detail-header{position:sticky;top:0;z-index:10;background:var(--bg-primary);border-bottom:1px solid var(--border-color);padding:var(--space-3) 0;margin-bottom:var(--space-3);display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);flex-wrap:wrap}.billing-detail-header-left{display:flex;align-items:center;gap:var(--space-3);min-width:0}.billing-detail-header-right{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.billing-back-btn{display:flex;align-items:center;gap:5px;padding:5px 10px;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);font-size:.78rem;cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s;flex-shrink:0}.billing-back-btn:hover{color:var(--text-primary);border-color:var(--border-light)}.billing-detail-title-block{display:flex;align-items:center;gap:var(--space-2);min-width:0;flex-wrap:wrap}.billing-detail-title{font-size:1.05rem;font-weight:700;color:var(--text-primary);margin:0;white-space:nowrap}.billing-detail-dash{color:var(--text-muted);font-weight:300}.billing-detail-project{font-size:1rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.billing-search-inline{display:flex;align-items:center;gap:5px;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:6px;padding:5px 10px;color:var(--text-tertiary)}.billing-search-inline input{background:transparent;border:none;outline:none;font-size:.78rem;color:var(--text-primary);width:160px}.billing-search-inline input::placeholder{color:var(--text-muted)}.billing-year-banner{display:flex;align-items:flex-start;gap:8px;font-size:.78rem;padding:10px 14px;border-radius:8px;border:1px solid;margin-bottom:var(--space-3);line-height:1.5}.billing-banner-icon{font-style:normal;font-size:1rem;flex-shrink:0;line-height:1.5}.billing-year-banner-current{background:#22c55e0f;border-color:#22c55e2e;color:var(--text-secondary)}.billing-year-banner-future{background:#6366f10f;border-color:#6366f12e;color:var(--text-secondary)}.billing-th-client,.billing-td-client{text-align:left!important;min-width:130px;width:130px;position:sticky;left:0;background:var(--bg-elevated);z-index:2;border-right:none}.billing-td-client{background:var(--bg-secondary);z-index:1;vertical-align:top;padding-top:10px}.billing-th-stack,.billing-td-stack{text-align:left!important;min-width:180px;width:180px;position:sticky;left:130px;background:var(--bg-elevated);z-index:2;border-right:1px solid var(--border-color)}.billing-td-stack{background:var(--bg-secondary);z-index:1}.billing-service-row:hover .billing-td-client,.billing-service-row:hover .billing-td-stack{background:var(--bg-hover)}.billing-totals-row .billing-td-client,.billing-totals-row .billing-td-stack{background:var(--bg-elevated)!important}.billing-project-label-cell{display:block;font-size:.8rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.billing-service-name{color:var(--text-secondary);font-size:.78rem}.billing-empty-row{text-align:center!important;padding:24px!important;color:var(--text-muted);font-style:italic}.billing-users-row th{background:#6366f10d!important;border-top:1px solid rgba(99,102,241,.12);border-bottom:1px solid rgba(99,102,241,.12)}.billing-users-header{text-align:left!important;padding:8px 10px!important;position:sticky!important;left:0!important;z-index:3!important}.billing-users-header-inner{display:flex;align-items:flex-start;gap:8px}.billing-users-icon{color:var(--accent-primary);margin-top:2px;flex-shrink:0}.billing-users-title{font-size:.75rem;font-weight:600;color:var(--accent-primary);line-height:1.3}.billing-users-subtitle{font-size:.68rem;color:var(--text-muted);font-weight:400;margin-top:1px}.billing-users-cell-th{padding:6px 8px!important}.billing-td-forecast-col,.billing-th-forecast-col{background:#f59e0b0f!important}.billing-service-row:hover .billing-td-forecast-col{background:#f59e0b1a!important}.billing-user-historical{display:inline-block;font-size:.73rem;font-weight:500;font-variant-numeric:tabular-nums;color:var(--text-secondary);padding:3px 6px;border-radius:4px;background:var(--bg-tertiary);border:1px solid var(--border-subtle);cursor:default}.billing-user-cell{display:inline-flex;align-items:center;gap:4px;cursor:pointer;padding:3px 6px;border-radius:4px;font-size:.73rem;font-variant-numeric:tabular-nums;transition:background .12s;white-space:nowrap;font-weight:500}.billing-user-add{color:var(--text-muted);border:1px dashed var(--border-color)}.billing-user-add:hover{color:var(--accent-primary);border-color:var(--accent-primary);background:var(--accent-primary-light)}.billing-user-set{color:var(--accent-primary);background:var(--accent-primary-light);border:1px solid rgba(99,102,241,.25)}.billing-user-set:hover{background:#6366f126}.billing-user-edit-icon{opacity:.6}.billing-user-input{width:60px;padding:2px 5px;background:var(--bg-primary);border:1px solid var(--accent-primary);border-radius:4px;color:var(--accent-primary);font-size:.75rem;font-variant-numeric:tabular-nums;outline:none}.billing-user-count-badge{display:inline-flex;align-items:center;gap:3px;font-size:.7rem;font-weight:600;color:var(--accent-primary);background:var(--accent-primary-light);border:1px solid rgba(99,102,241,.25);border-radius:10px;padding:2px 7px}.billing-service-row{transition:background .1s}.billing-service-row:hover{background:var(--bg-hover)}.project-detail{max-width:1400px}.pd-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-5)}.pd-env-pill{margin-left:.5rem;font-size:.6875rem;font-weight:600;padding:.15rem .5rem;border-radius:4px;background:#38bdf81f;color:#38bdf8;border:1px solid rgba(56,189,248,.3);text-transform:uppercase;letter-spacing:.04em;vertical-align:middle}.pd-header-left{display:flex;align-items:center;gap:var(--space-3)}.pd-back-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.pd-back-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.pd-project-name{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.pd-tabs{display:flex;gap:0;margin-bottom:var(--space-6);background:var(--bg-elevated);border-radius:var(--radius-xl);padding:4px}.pd-tab{flex:1;text-align:center;padding:var(--space-3) var(--space-4);font-size:.875rem;font-weight:500;color:var(--text-tertiary);cursor:pointer;border:none;border-radius:var(--radius-lg);transition:all var(--transition-fast);background:transparent;white-space:nowrap}.pd-tab:hover:not(.pd-tab-active){color:var(--text-secondary)}.pd-tab-active{color:#fff;font-weight:600;background:var(--accent-primary);box-shadow:0 2px 10px #7000ff66}.pd-techstack{margin-top:var(--space-4)}.pd-techstack-flow{width:100%;display:flex;flex-direction:column;align-items:flex-start}.env-health-stack{position:relative;width:350px;max-width:100%;flex-shrink:0;align-self:flex-start;isolation:isolate}.env-health-stack--with-flow .env-health-flow-spacer{height:48px}.env-health-angular-flow{position:absolute;left:45px;top:0;width:100%;max-width:350px;height:auto;aspect-ratio:378 / 136;display:block;pointer-events:none;z-index:2;overflow:visible}.ts-tray{max-width:1150px;margin-left:auto;margin-right:auto;padding:0 var(--space-4)}.env-status-card{width:350px;height:88px;border-radius:12px;display:flex;align-items:center;gap:14px;padding:14px;box-sizing:border-box;position:relative;overflow:visible}.env-status-card--healthy{border:1px solid rgba(34,197,94,.45);background:#0c2218eb}.env-status-card--building{border:1px solid rgba(245,158,11,.5);background:#2d200aeb}.env-status-card--unhealthy{border:1px solid rgba(239,68,68,.5);background:#281212eb}.env-status-left{height:100%;display:flex;align-items:stretch}.env-status-pill{border-radius:10px;border:1px solid rgba(34,197,94,.55);background:#0f3c26b3;color:#22c55e;font-weight:800;letter-spacing:.08em;font-size:1rem;padding:12px 14px;line-height:1;height:100%;display:flex;align-items:center;box-sizing:border-box}.env-status-pill-btn{cursor:pointer}.env-status-pill-btn:hover{background:#12462dbf;border-color:#22c55ebf}.env-status-card--building .env-status-pill{border-color:#f59e0b8c;background:#462d0c8c;color:#fbbf24}.env-status-card--building .env-status-pill-btn:hover{background:#5a370eb8;border-color:#f59e0bbf}.env-status-card--unhealthy .env-status-pill{border-color:#ef44448c;background:#4619198c;color:#f87171}.env-status-card--unhealthy .env-status-pill-btn:hover{background:#5a1e1eb8;border-color:#ef4444bf}.env-status-dropdown{position:absolute;top:calc(100% + 2px);left:0;right:0;width:100%;padding:8px;border-radius:12px;background:#121814fa;border:1px solid rgba(255,255,255,.1);box-shadow:0 16px 60px #0000008c;z-index:50;display:none}.env-status-dropdown:before{content:"";position:absolute;left:0;right:0;top:-10px;height:10px}.env-status-card:hover .env-status-dropdown{display:block}.env-status-dd-item{width:100%;display:grid;grid-template-columns:54px 1fr;gap:10px;align-items:center;padding:10px;border-radius:10px;border:1px solid transparent;background:transparent;color:#e5e7eb;cursor:pointer;text-align:left}.env-status-dd-item:hover{background:#ffffff0f;border-color:#7000ff40}.env-status-dd-item.is-active{background:#22c55e1a;border-color:#22c55e40}.env-status-dd-key{font-weight:900;letter-spacing:.08em;color:#22c55e}.env-status-dd-name{font-weight:700;color:#fff}.env-status-right{display:flex;flex-direction:column;gap:6px;min-width:0}.env-status-name{color:#fff;font-weight:700;font-size:1.15rem;line-height:1.05;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.env-status-health{display:flex;align-items:center;gap:8px;font-size:.95rem;font-weight:600;opacity:.9}.env-status-probe{width:11px;height:11px;border-radius:999px;flex:0 0 auto}.env-status-health-healthy{color:#22c55e}.env-status-health-healthy .env-status-probe{background:#22c55e}.env-status-health-building{color:#f59e0b}.env-status-health-building .env-status-probe{background:#f59e0b}.env-status-health-unhealthy{color:#ef4444}.env-status-health-unhealthy .env-status-probe{background:#ef4444}.ts-grid{display:flex;flex-direction:column;gap:0;position:relative}.ts-row{display:grid;grid-template-columns:1fr 118px 1fr;align-items:center;gap:0}.ts-vrow{display:grid;grid-template-columns:1fr 118px 1fr;height:84px;align-items:center}.ts-card-anchor{display:flex;flex-direction:column;min-width:0;min-height:150px;height:100%}.ts-card-anchor>.ts-card{flex:1}.ts-card{display:flex;flex-direction:column;padding:var(--space-4);cursor:pointer;transition:all var(--transition-slow);position:relative;text-decoration:none;color:inherit;min-height:150px;border:1px solid var(--border-color)}.ts-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-xl),0 0 0 1px #7000ff40;border-color:#7000ff4d}.ts-card-inner{display:flex;gap:var(--space-4);align-items:center;flex:1;margin-bottom:var(--space-3)}.ts-card-icon{flex-shrink:0;width:88px;height:88px;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.ts-app-icon{width:76px;height:76px;display:block;object-fit:contain}.ts-app-icon-fallback{width:76px;height:76px;border-radius:16px;background:#ffffff0f}.ts-card-body{flex:1;min-width:0}.ts-type-badge{display:inline-flex;align-items:center;padding:5px 12px;border-radius:56px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-bottom:var(--space-2);line-height:1}.ts-type-badge.type-frontend{background:#f59e0b26;color:#f59e0b}.ts-type-badge.type-ecs{background:#6366f126;color:#818cf8}.ts-type-badge.type-serverless{background:#10b98126;color:#34d399}.ts-type-badge.type-rds{background:#8b5cf626;color:#a78bfa}.ts-type-badge.type-mongodb{background:#22c55e26;color:#4ade80}.ts-type-badge.type-redis{background:#ef444426;color:#f87171}.ts-card-name{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--space-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ts-card-url{font-size:.75rem;color:var(--accent-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.ts-card-footer{display:flex;align-items:center;gap:var(--space-2);padding-top:var(--space-3);border-top:1px solid var(--border-color)}.ts-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.ts-status-ready{background:var(--accent-success);box-shadow:0 0 6px #22c55e80}.ts-status-deploying{background:var(--accent-warning);animation:pulse 1.5s ease-in-out infinite}.ts-status-inactive{background:var(--text-muted)}.ts-status-failed{background:var(--accent-error);box-shadow:0 0 6px #ef444480}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.ts-status-label{font-size:.8125rem;color:var(--text-secondary);flex:1}.ts-ext-link{color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.ts-ext-link:hover{background:var(--bg-hover);color:var(--accent-primary)}.ts-delete-btn{opacity:0;color:var(--text-tertiary);width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.ts-card:hover .ts-delete-btn{opacity:1}.ts-delete-btn:hover{color:var(--accent-error);background:var(--bg-tertiary)}.ts-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;overflow:visible;z-index:2}.ts-overlay path{fill:none;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter}.ts-arrow-wrapper-h{display:flex;align-items:center;justify-content:center;width:118px;padding:0 12px;box-sizing:border-box}.ts-arrow-wrapper-v{display:flex;align-items:center;justify-content:center;height:84px;padding:12px 0;box-sizing:border-box}.ts-arrow-empty{visibility:hidden}.ts-arrow-h{width:72px;height:28px;display:block}.ts-arrow-v{width:28px;height:56px;display:block}.ts-card-filler{min-height:130px}.ext-resource-sections{display:flex;flex-direction:row;align-items:flex-start;gap:0;flex-wrap:wrap}.ext-resource-section{display:flex;flex-direction:column;gap:var(--space-3);min-width:200px;max-width:280px;flex:1}.ext-section-label{font-size:.6875rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);padding:0 var(--space-1)}.ext-section-cards{display:flex;flex-direction:column;gap:var(--space-3)}.ext-section-arrow-wrap{display:flex;align-items:center;justify-content:center;padding:0 var(--space-3);padding-top:28px;flex-shrink:0}.ext-ts-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--bg-secondary)}.ext-ts-card-icon{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center}.ext-ts-card-info{display:flex;flex-direction:column;gap:2px;min-width:0}.ext-ts-card-type{font-size:.625rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-tertiary)}.ext-ts-card-name{font-size:.8125rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ts-skeleton-grid{display:grid;grid-template-columns:1fr 118px 1fr;gap:var(--space-4)}.pd-tab-placeholder{display:flex;align-items:center;justify-content:center;padding:var(--space-16);color:var(--text-tertiary);font-size:.9375rem}.app-type-badge{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);background:var(--bg-tertiary);font-size:.75rem;font-weight:500;color:var(--text-secondary)}.app-type-badge.type-frontend{background:#f59e0b1f;color:#f59e0b}.app-type-badge.type-ecs{background:#6366f11f;color:var(--accent-primary)}.app-type-badge.type-serverless{background:#10b9811f;color:var(--accent-success)}.app-type-badge.type-rds{background:#14b8a61f;color:#14b8a6}.app-type-badge.type-mongodb{background:#22c55e1f;color:#22c55e}.app-type-badge.type-redis{background:#dc26261f;color:#ef4444}.app-type-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);margin-top:var(--space-2)}.app-type-option{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-4);border:2px solid var(--border-color);border-radius:var(--radius-lg);background:var(--bg-secondary);cursor:pointer;transition:all var(--transition-fast);text-align:center}.app-type-option:hover{border-color:var(--accent-primary);background:var(--bg-tertiary)}.app-type-option.selected{border-color:var(--accent-primary);background:#7000ff1a}.app-type-option svg{color:#fff}.app-type-option-icon{width:24px;height:24px;object-fit:contain;flex-shrink:0}.app-type-option strong{font-size:.875rem;color:var(--text-primary)}.app-type-option span{font-size:.75rem;color:var(--text-secondary);line-height:1.3}.app-type-option.disabled,.app-type-option:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.app-type-disabled-badge{font-size:.625rem!important;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--accent-error)!important;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-sm);padding:1px 5px}.project-detail .error-banner{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);background:#ef44441a;color:var(--accent-error);font-size:.875rem;margin-bottom:var(--space-4)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:calc(var(--header-height, 68px) + var(--space-8) + var(--space-4)) var(--space-4) var(--space-8);z-index:1000;overflow-y:auto;animation:fadeIn .2s ease-out}.modal{width:100%;max-width:560px;max-height:calc(100dvh - var(--header-height, 68px) - var(--space-16));overflow-y:auto;flex-shrink:0;animation:slideUp .3s ease-out}.modal.modal-sm{max-width:400px}.modal-header h2{font-size:1.125rem;font-weight:600}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--text-tertiary);transition:all var(--transition-fast)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-5);border-top:1px solid var(--border-color)}.delete-warning{font-size:.9375rem;line-height:1.6;color:var(--text-secondary)}.delete-warning strong{color:var(--text-primary)}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-danger:hover{background:linear-gradient(135deg,#dc2626,#b91c1c)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16);text-align:center}.empty-icon{font-size:3rem;margin-bottom:var(--space-4)}.empty-state p{color:var(--text-secondary);margin-bottom:var(--space-6)}.skeleton-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-5);animation:fadeIn .3s ease-out}.pd-analytics-wrap{display:flex;flex-direction:column;gap:var(--space-5)}.pd-analytics-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}.pd-analytics-stat{padding:var(--space-5)}.pd-anstat-label{font-size:.625rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:8px}.pd-anstat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.pd-anstat-apps{display:flex;align-items:center;gap:6px;font-size:.8125rem;color:var(--text-secondary);font-weight:500;padding-top:4px}.pd-app-status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.pd-dot-ready{background:#22c55e;box-shadow:0 0 6px #22c55e80}.pd-dot-building{background:#f59e0b;animation:pulse 1.5s infinite}.pd-dot-inactive{background:#6b7280}.pd-analytics-chart{padding:var(--space-5)}.pd-analytics-chart-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-5)}.pd-analytics-chart-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:2px}.pd-analytics-chart-sub{font-size:.75rem;color:var(--text-tertiary)}.pd-success-badge{display:flex;align-items:center;gap:5px;font-size:.75rem;font-weight:600;color:#22c55e;background:#22c55e1a;border:1px solid rgba(34,197,94,.25);border-radius:var(--radius-full);padding:4px 10px}@media (max-width: 640px){.app-type-selector,.ts-row,.ts-vrow,.ts-skeleton-grid{grid-template-columns:1fr}.ts-arrow-wrapper-h{display:none}.pd-analytics-stats{grid-template-columns:repeat(2,1fr)}}.domains-page{max-width:1400px}.domains-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-6);gap:var(--space-4)}.header-content h2{font-size:1.5rem;font-weight:700;margin-bottom:var(--space-2)}.header-description{font-size:.875rem;color:var(--text-secondary)}.domains-list{display:flex;flex-direction:column;gap:var(--space-4)}.domain-card{padding:var(--space-5);display:flex;align-items:center;justify-content:space-between;gap:var(--space-4)}.domain-header{display:flex;align-items:center;gap:var(--space-4);flex:1}.domain-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#3b82f61a;border-radius:var(--radius-md);color:var(--accent-primary)}.domain-info{flex:1}.domain-info h4{font-size:.9375rem;font-weight:600;margin-bottom:var(--space-1)}.domain-meta{font-size:.75rem;color:var(--text-tertiary);text-transform:capitalize}.domain-actions{display:flex;align-items:center;gap:var(--space-2)}.status-badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:.75rem;font-weight:500}.status-active{background:#22c55e1a;color:var(--accent-success)}.domain-info-tooltip{display:flex;align-items:center;color:var(--text-tertiary);cursor:help;transition:color var(--transition-fast);margin-left:var(--space-2)}.domain-info-tooltip:hover{color:var(--accent-primary)}.status-pending{background:#fbbf241a;color:var(--accent-warning)}.status-failed{background:#ef44441a;color:var(--accent-error)}.empty-state{padding:var(--space-16);text-align:center}.empty-icon{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;background:var(--bg-tertiary);border-radius:var(--radius-full);color:var(--text-muted);margin-bottom:var(--space-4)}.empty-state h3{font-size:1.25rem;font-weight:600;margin-bottom:var(--space-2)}.empty-state p{color:var(--text-secondary);margin-bottom:var(--space-6);max-width:400px;margin-left:auto;margin-right:auto}.dns-instructions{padding:var(--space-4);background:var(--bg-tertiary);border:1px solid var(--border-color);margin-top:var(--space-4)}.dns-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3)}.dns-header h4{font-size:.875rem;font-weight:600;margin:0}.dns-instructions p{font-size:.8125rem;color:var(--text-secondary);margin-bottom:var(--space-2)}.dns-instructions ul{list-style:none;margin:var(--space-2) 0;padding:0}.dns-instructions li{font-size:.8125rem;color:var(--text-secondary);margin-bottom:var(--space-2);padding-left:var(--space-5);position:relative}.dns-instructions li:before{content:"→";position:absolute;left:0;color:var(--accent-primary)}.dns-instructions code{background:var(--bg-primary);padding:2px 6px;border-radius:4px;font-family:Monaco,Courier New,monospace;font-size:.75rem;color:var(--accent-primary)}.dns-note{margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--border-color);font-size:.75rem;color:var(--text-tertiary)}.error-alert{background:#ef44441a;border:1px solid var(--accent-error);color:var(--accent-error);padding:var(--space-3);border-radius:var(--radius-md);margin-bottom:var(--space-4);font-size:.875rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{width:90%;max-width:500px;max-height:90vh;overflow-y:auto;animation:modalFadeIn .2s ease}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5);border-bottom:1px solid var(--border-color)}.modal-header h2{font-size:1.125rem;font-weight:600;margin:0}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-muted);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-body{padding:var(--space-5)}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-5);border-top:1px solid var(--border-color)}.input-group label{display:block;font-size:.875rem;font-weight:500;margin-bottom:var(--space-2);color:var(--text-primary)}.input{width:100%;padding:var(--space-2) var(--space-3);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem}.input:focus{outline:none;border-color:var(--accent-primary)}select.input{cursor:pointer}.radio-group{display:flex;gap:var(--space-4)}.radio-label{display:flex;align-items:center;gap:var(--space-2);cursor:pointer}.radio-label input[type=radio]{cursor:pointer}.radio-label span{font-size:.875rem;color:var(--text-primary)}.input-hint{display:block;margin-top:var(--space-1);font-size:.75rem;color:var(--text-tertiary)}.text-danger,.text-danger:hover{color:var(--accent-error)}.loading-center{display:flex;align-items:center;justify-content:center;min-height:400px;color:var(--text-muted)}@media (max-width: 768px){.domains-header{flex-direction:column}.domain-card{flex-direction:column;align-items:flex-start}.domain-header{width:100%}.domain-actions{width:100%;justify-content:flex-end}}.media-storage{padding:2rem;max-width:1400px}.media-storage h1{font-size:1.75rem;font-weight:700;margin-bottom:.5rem;color:var(--text-primary, #fff)}.media-storage .page-subtitle{color:var(--text-secondary, #999);margin-bottom:2rem;font-size:.95rem}.media-card{background:var(--card-bg, rgba(255, 255, 255, .05));border:1px solid var(--border-color, rgba(255, 255, 255, .1));border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.media-card h2{font-size:1.15rem;font-weight:600;margin-bottom:1rem;color:var(--text-primary, #fff);display:flex;align-items:center;gap:.5rem}.media-card h2 svg{color:var(--accent, #6366f1)}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-item.full-width{grid-column:1 / -1}.info-label{font-size:.8rem;color:var(--text-secondary, #999);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.info-value{font-size:.95rem;color:var(--text-primary, #fff);font-family:SF Mono,Fira Code,monospace;background:#0003;padding:.5rem .75rem;border-radius:6px;border:1px solid rgba(255,255,255,.06);word-break:break-all}.credentials-empty{text-align:center;padding:2rem 1rem}.credentials-empty p{color:var(--text-secondary, #999);margin-bottom:1.5rem;font-size:.95rem}.credential-row{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background:#00000026;border-radius:8px;margin-bottom:.75rem;border:1px solid rgba(255,255,255,.06)}.credential-row:last-child{margin-bottom:0}.credential-label{font-size:.8rem;color:var(--text-secondary, #999);min-width:120px;font-weight:500}.credential-value{flex:1;font-family:SF Mono,Fira Code,monospace;font-size:.9rem;color:var(--text-primary, #fff);padding:0 .5rem;word-break:break-all}.status-badge{padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.active{background:#22c55e26;color:#22c55e;border:1px solid rgba(34,197,94,.3)}.status-badge.inactive{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.secret-reveal{background:#6366f114;border:1px solid rgba(99,102,241,.25);border-radius:10px;padding:1.25rem;margin-top:1rem}.secret-reveal h3{color:#6366f1;font-size:.9rem;font-weight:600;margin-bottom:.5rem;display:flex;align-items:center;gap:.4rem}.secret-reveal .warning-text{color:#eab308;font-size:.8rem;margin-bottom:.75rem;display:flex;align-items:center;gap:.4rem}.secret-value-container{display:flex;align-items:center;gap:.5rem}.secret-value{flex:1;font-family:SF Mono,Fira Code,monospace;font-size:.85rem;color:var(--text-primary, #fff);background:#0000004d;padding:.6rem .75rem;border-radius:6px;border:1px solid rgba(255,255,255,.1);word-break:break-all}.btn-group{display:flex;gap:.75rem;margin-top:1.25rem;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;border-radius:8px;border:none;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#5558e6,#7c4fe0);transform:translateY(-1px);box-shadow:0 4px 12px #6366f159}.btn-warning{background:#eab30826;color:#eab308;border:1px solid rgba(234,179,8,.3)}.btn-warning:hover:not(:disabled){background:#eab30840}.btn-danger{background:#ef44441f;color:#ef4444;border:1px solid rgba(239,68,68,.25)}.btn-danger:hover:not(:disabled){background:#ef444438}.btn-ghost{background:#ffffff0f;color:var(--text-secondary, #999);border:1px solid rgba(255,255,255,.1)}.btn-ghost:hover:not(:disabled){background:#ffffff1a;color:var(--text-primary, #fff)}.btn-copy{padding:.4rem .6rem;min-width:auto}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease}.modal-content{background:var(--card-bg, #1a1a2e);border:1px solid var(--border-color, rgba(255, 255, 255, .1));border-radius:14px;padding:1.75rem;max-width:440px;width:90%;animation:slideUp .2s ease}.modal-content h3{font-size:1.1rem;font-weight:600;color:var(--text-primary, #fff);margin-bottom:.75rem}.modal-content p{color:var(--text-secondary, #999);font-size:.9rem;margin-bottom:1.5rem;line-height:1.5}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem}@keyframes slideUp{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.usage-instructions{margin-top:0}.usage-instructions pre{background:#0000004d;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:1rem;overflow-x:auto;font-family:SF Mono,Fira Code,monospace;font-size:.82rem;line-height:1.6;color:#e2e8f0}.usage-instructions code{color:inherit}.usage-instructions p{color:var(--text-secondary, #999);font-size:.9rem;margin-bottom:.75rem}.media-loading{display:flex;align-items:center;justify-content:center;padding:4rem;color:var(--text-secondary, #999);gap:.75rem}.media-loading .spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.1);border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite}.media-error{text-align:center;padding:2rem;color:#ef4444}@media (max-width: 640px){.media-storage{padding:1rem}.info-grid{grid-template-columns:1fr}.credential-row{flex-direction:column;align-items:flex-start;gap:.3rem}.btn-group{flex-direction:column}.btn{justify-content:center}}.deployments-page{max-width:1400px}.deployments-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-5);flex-wrap:wrap;gap:var(--space-4)}.deployments-title-section{display:flex;align-items:baseline;gap:var(--space-3);flex-shrink:0}.deployments-title-section h2{font-size:1.5rem;font-weight:700}.deployments-count{font-size:.875rem;color:var(--text-tertiary)}.deployments-toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:var(--space-3);flex:1;min-width:0}.deployments-filters{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3)}.deployments-filters .multi-select-filter{width:200px}.deployments-search{position:relative;width:260px;min-width:180px}.deployments-search .search-icon{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);color:var(--text-muted);transition:color var(--transition-fast)}.deployments-search:focus-within .search-icon{color:var(--accent-primary)}.deployments-search .input{padding-left:var(--space-10);border-radius:var(--radius-xl);background:var(--bg-secondary);border-color:var(--border-color);font-weight:500}.deployments-search .input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-light)}.deployments-tabs{display:flex;gap:var(--space-1);margin-bottom:var(--space-5);border-bottom:1px solid var(--border-color);padding-bottom:0}.tab-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);font-size:.875rem;font-weight:500;color:var(--text-tertiary);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all var(--transition-fast);background:none;border-top:none;border-left:none;border-right:none;cursor:pointer}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.tab-count{font-size:.6875rem;font-weight:600;padding:1px 6px;border-radius:10px;background:var(--accent-primary);color:#fff}.tab-count-error{background:var(--accent-error)}.deployments-table{position:relative;overflow:visible}.deployments-table-body{overflow:hidden;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.deployments-columns-picker{position:relative;display:flex;align-items:center;justify-content:center}.deployments-columns-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-tertiary);cursor:pointer;transition:border-color var(--transition-fast),color var(--transition-fast),background var(--transition-fast)}.deployments-columns-btn:hover{color:var(--text-primary);border-color:var(--text-muted);background:var(--bg-hover)}.deployments-columns-btn.open{border-color:var(--accent-primary);color:var(--accent-primary)}.deployments-columns-dot{position:absolute;top:3px;right:3px;width:5px;height:5px;border-radius:50%;background:var(--accent-primary)}.deployments-columns-menu{position:absolute;top:calc(100% + 4px);right:0;z-index:100;min-width:168px;max-height:260px;overflow-y:auto;padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-primary);box-shadow:var(--shadow-lg, 0 8px 24px rgba(0, 0, 0, .14))}.deployments-columns-menu ul{list-style:none;margin:0;padding:0}.deployments-columns-option{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);border-radius:var(--radius-sm);font-size:.8125rem;line-height:1.35;color:var(--text-secondary);cursor:pointer}.deployments-columns-option:hover{background:var(--bg-hover)}.deployments-columns-option input{width:14px;height:14px;margin:0;flex-shrink:0;accent-color:var(--accent-primary)}.deployments-table-head,.deployment-sub-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4)}.deployments-table-head{font-size:.75rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border-color);background:var(--bg-tertiary)}.dep-col{min-width:0;flex-shrink:0}.dep-col-status{width:118px}.dep-col-env{width:108px}.dep-col-app{flex:1 1 140px;min-width:100px}.dep-col-branch{width:100px;display:flex;align-items:center;gap:var(--space-1);font-family:var(--font-mono, monospace);font-size:.75rem;color:var(--text-tertiary)}.dep-col-branch svg{width:12px;height:12px}.dep-col-started{width:118px;font-size:.75rem;color:var(--text-tertiary);white-space:nowrap}.dep-col-optional{width:120px;font-size:.75rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dep-col-projectId,.dep-col-appId,.dep-col-deploymentId{font-family:monospace;font-size:.75rem;color:var(--text-tertiary)}.dep-col-commit,.dep-col-error{width:160px}.dep-col-action{width:32px;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.deployments-table-head .dep-col-action{overflow:visible;z-index:5}.platform-group+.platform-group{border-top:1px solid var(--border-color)}.platform-group-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-2) var(--space-4);min-height:34px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.platform-group-name{font-size:.875rem;font-weight:600;color:var(--text-primary);line-height:1.3}.platform-group-count{font-size:.75rem;font-weight:500;color:var(--text-tertiary);white-space:nowrap}.deployment-sub-row{font-size:.8125rem;color:var(--text-secondary);border-bottom:1px solid var(--border-color);text-decoration:none;cursor:pointer;transition:background var(--transition-fast);min-height:40px}.deployment-sub-row:last-child{border-bottom:none}.deployment-sub-row:hover{background:var(--bg-hover)}.deployment-sub-row:hover .dep-col-action{color:var(--accent-primary)}.env-pill{display:inline-block;padding:2px 8px;border-radius:var(--radius-md);font-size:.6875rem;font-weight:600;background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);white-space:nowrap}.app-name-cell{font-weight:500;font-size:.8125rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.dep-col-status{display:flex;align-items:center}.loading-center{display:flex;align-items:center;justify-content:center;padding:var(--space-16);color:var(--text-tertiary)}@media (max-width: 1024px){.dep-col-optional{width:96px}.dep-col-commit,.dep-col-error{width:120px}}@media (max-width: 768px){.deployments-header,.deployments-toolbar{flex-direction:column;align-items:stretch}.deployments-filters .multi-select-filter,.deployments-search{width:100%}.deployments-table-head{display:none}.deployment-sub-row{flex-wrap:wrap;padding:var(--space-4);padding-left:var(--space-4);gap:var(--space-2)}.dep-col-status{order:1}.dep-col-env{order:2;width:auto}.dep-col-app{order:3;flex:1 1 100%}.dep-col-started{order:4;width:auto}.dep-col-branch{order:5;width:100%}.dep-col-optional{order:6;width:100%}.dep-col-action{order:7;margin-left:auto}}.cost-calculator{max-width:1100px;margin:0 auto;padding:var(--space-6) var(--space-4)}.calculator-header{text-align:center;margin-bottom:var(--space-6)}.calculator-icon{color:var(--accent-primary);margin-bottom:var(--space-2)}.calculator-header h2{font-size:1.75rem;font-weight:700;margin-bottom:var(--space-2);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.calculator-header p{color:var(--text-secondary);font-size:.9375rem}.platform-costs-banner{padding:var(--space-4) var(--space-5);margin-bottom:var(--space-6);background:#3b82f614;border-color:#3b82f633}.platform-costs-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-2)}.platform-costs-header h3{flex:1;font-size:.9375rem;font-weight:600;color:var(--text-primary)}.platform-total{font-size:1rem;font-weight:700;color:var(--accent-primary)}.platform-note{font-size:.8125rem;color:var(--text-secondary);margin-bottom:var(--space-3)}.platform-breakdown{display:flex;flex-wrap:wrap;gap:var(--space-3) var(--space-5);font-size:.75rem;color:var(--text-tertiary)}.calculator-grid{display:grid;grid-template-columns:380px 1fr;gap:var(--space-5);margin-bottom:var(--space-6)}.calculator-inputs{padding:var(--space-5)}.calculator-inputs h3{font-size:1rem;font-weight:600;margin-bottom:var(--space-5);color:var(--text-primary)}.input-slider{margin-bottom:var(--space-4)}.slider-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.slider-header label{display:flex;align-items:center;gap:var(--space-2);font-size:.8125rem;color:var(--text-secondary)}.slider-value{font-size:.9375rem;font-weight:600;color:var(--text-primary)}.slider-hint{display:block;font-size:.6875rem;color:var(--text-muted);margin-top:var(--space-1)}.input-slider input[type=range]{width:100%;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg-tertiary);border-radius:var(--radius-full);outline:none;cursor:pointer}.input-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:var(--gradient-primary);border-radius:50%;cursor:pointer;box-shadow:0 2px 8px #3b82f666;transition:transform var(--transition-fast)}.input-slider input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.1)}.deployment-type-row{margin-bottom:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.deployment-type-label{display:flex;align-items:center;gap:var(--space-2);font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2)}.deployment-type-toggle{display:flex;gap:var(--space-2)}.deploy-btn{flex:1;padding:var(--space-2) var(--space-3);font-size:.75rem;font-weight:500;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);background:var(--bg-secondary);cursor:pointer;transition:all .15s ease;text-align:center}.deploy-btn:hover{border-color:var(--accent-primary);color:var(--text-primary)}.deploy-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.advanced-section-title{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin:var(--space-4) 0 var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--border-color)}.tier-select{width:100%;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);color:var(--text-primary);font-size:.8125rem;cursor:pointer;margin-top:var(--space-2)}.tier-select:focus{outline:none;border-color:var(--accent-primary)}.runtime-badge{display:inline-block;margin-left:var(--space-2);padding:1px var(--space-2);font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;background:var(--accent-primary-light);color:var(--accent-primary);border-radius:var(--radius-sm);vertical-align:middle}.advanced-toggle{width:100%;padding:var(--space-2);font-size:.75rem;color:var(--text-tertiary);text-align:center;border-top:1px solid var(--border-color);margin-top:var(--space-3);transition:color var(--transition-fast)}.advanced-toggle:hover{color:var(--accent-primary)}.advanced-settings{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border-color)}.calculator-results{display:flex;flex-direction:column;gap:var(--space-4)}.total-cost.tenant-cost{padding:var(--space-5);text-align:center;background:var(--gradient-primary);border:none;border-radius:var(--radius-lg)}.total-label{display:block;font-size:.8125rem;color:#fffc;margin-bottom:var(--space-2)}.total-amount{display:block;font-size:2.5rem;font-weight:700;color:#fff;line-height:1;margin-bottom:var(--space-2)}.per-app{font-size:.875rem;color:#ffffffb3}.cost-breakdown{padding:var(--space-4)}.cost-breakdown h3{font-size:.9375rem;font-weight:600;margin-bottom:var(--space-4)}.breakdown-section{margin-bottom:var(--space-4);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-color)}.breakdown-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.section-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);font-weight:600;font-size:.875rem}.section-header svg{color:var(--accent-primary)}.section-total{margin-left:auto;color:var(--text-primary)}.section-items{margin-left:calc(16px + var(--space-2))}.section-item{display:flex;justify-content:space-between;padding:var(--space-1) 0;font-size:.75rem;color:var(--text-tertiary)}.section-item .info-icon{margin-left:var(--space-1);opacity:.5}.savings-note{padding:var(--space-4);background:#22c55e14;border-color:#22c55e33}.savings-note h4{font-size:.875rem;font-weight:600;margin-bottom:var(--space-3)}.savings-note ul{list-style:none;display:flex;flex-direction:column;gap:var(--space-2)}.savings-note li{font-size:.75rem;color:var(--text-secondary)}.calculator-footer{text-align:center}.pricing-disclaimer{font-size:.6875rem;color:var(--text-muted);max-width:600px;margin:0 auto}@media (max-width: 900px){.calculator-grid{grid-template-columns:1fr}.platform-breakdown{flex-direction:column;gap:var(--space-1)}}@media (max-width: 640px){.total-amount{font-size:2rem}.platform-costs-header{flex-wrap:wrap}.platform-total{width:100%;margin-top:var(--space-2)}}.pricing-page{max-width:1200px;margin:0 auto;padding:var(--space-4) var(--space-4) var(--space-8)}.pricing-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6)}.pricing-back-btn{display:flex;align-items:center;gap:var(--space-2);color:var(--text-secondary);font-size:.875rem;padding:var(--space-2) var(--space-3);flex-shrink:0}.pricing-back-btn:hover{color:var(--text-primary)}.pricing-title{display:flex;align-items:center;gap:var(--space-2)}.pricing-title-icon{color:var(--accent-primary)}.pricing-title h1{font-size:1.25rem;font-weight:700;margin:0;color:var(--text-primary)}.pricing-hero{text-align:center;margin-bottom:var(--space-12)}.pricing-hero h1{font-size:2.5rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-3)}.pricing-hero p{font-size:1.125rem;color:var(--text-secondary);margin-bottom:var(--space-6)}.billing-toggle{display:inline-flex;background:var(--bg-tertiary);border-radius:var(--radius-full);padding:var(--space-1);gap:var(--space-1)}.billing-toggle button{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-size:.875rem;font-weight:500;color:var(--text-secondary);transition:all var(--transition-fast)}.billing-toggle button.active{background:var(--gradient-primary);color:#fff}.discount-badge{font-size:.6875rem;padding:var(--space-1) var(--space-2);background:#22c55e33;color:var(--accent-success);border-radius:var(--radius-full)}.pricing-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6);margin-bottom:var(--space-12)}.pricing-card{position:relative;padding:var(--space-8);text-align:center;transition:all var(--transition-base)}.pricing-card:hover{transform:translateY(-4px)}.pricing-card.highlighted{border-color:var(--accent-primary);box-shadow:0 0 40px #3b82f633}.popular-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);padding:var(--space-1) var(--space-4);background:var(--gradient-primary);color:#fff;font-size:.75rem;font-weight:600;border-radius:var(--radius-full)}.card-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-4);background:var(--bg-elevated);border-radius:var(--radius-lg);color:var(--accent-primary)}.highlighted .card-icon{background:var(--gradient-primary);color:#fff}.tier-name{font-size:1.25rem;font-weight:600;margin-bottom:var(--space-2)}.tier-description{font-size:.875rem;color:var(--text-secondary);margin-bottom:var(--space-6)}.tier-price{display:flex;align-items:baseline;justify-content:center;gap:var(--space-1);margin-bottom:var(--space-2)}.tier-price .currency{font-size:1.5rem;font-weight:600;color:var(--text-secondary)}.tier-price .amount{font-size:3rem;font-weight:700;line-height:1}.tier-price .period{font-size:1rem;color:var(--text-tertiary)}.tier-apps{font-size:.875rem;color:var(--text-secondary);margin-bottom:var(--space-6)}.tier-cta{width:100%;margin-bottom:var(--space-6)}.feature-list{list-style:none;text-align:left}.feature-list li{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) 0;font-size:.875rem;border-bottom:1px solid var(--border-color)}.feature-list li:last-child{border-bottom:none}.feature-list li.included{color:var(--text-primary)}.feature-list li.excluded{color:var(--text-tertiary)}.check-icon{color:var(--accent-success)}.x-icon{color:var(--text-muted)}.enterprise-cta{display:flex;align-items:center;justify-content:space-between;padding:var(--space-8);margin-bottom:var(--space-12)}.enterprise-content h2{font-size:1.5rem;font-weight:600;margin-bottom:var(--space-2)}.enterprise-content p{font-size:.9375rem;color:var(--text-secondary);max-width:600px}.faq-section{margin-bottom:var(--space-12)}.faq-section h2{text-align:center;font-size:1.75rem;font-weight:600;margin-bottom:var(--space-8)}.faq-list{display:flex;flex-direction:column;gap:var(--space-3);max-width:800px;margin:0 auto}.faq-item{padding:var(--space-4) var(--space-5);cursor:pointer;transition:all var(--transition-fast)}.faq-item:hover{background:var(--glass-hover)}.faq-question{display:flex;align-items:center;justify-content:space-between;font-weight:500}.faq-toggle{font-size:1.25rem;color:var(--text-tertiary)}.faq-answer{margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--border-color);font-size:.9375rem;color:var(--text-secondary);line-height:1.6}.final-cta{text-align:center;padding:var(--space-12) var(--space-8);background:var(--bg-secondary);border-radius:var(--radius-xl);border:1px solid var(--border-color)}.final-cta h2{font-size:2rem;font-weight:600;margin-bottom:var(--space-2)}.final-cta p{font-size:1.125rem;color:var(--text-secondary);margin-bottom:var(--space-6)}@media (max-width: 1024px){.pricing-cards{grid-template-columns:1fr;max-width:400px;margin-left:auto;margin-right:auto}.pricing-card.highlighted{order:-1}.enterprise-cta{flex-direction:column;text-align:center;gap:var(--space-4)}.enterprise-content p{max-width:none}}@media (max-width: 640px){.pricing-hero h1{font-size:1.75rem}.tier-price .amount{font-size:2.5rem}}.settings-page{max-width:1400px}.settings-header{margin-bottom:var(--space-6)}.settings-header h2{font-size:1.5rem;font-weight:700}.settings-layout{display:grid;grid-template-columns:220px 1fr;gap:var(--space-6);align-items:start}.settings-sidebar{display:flex;flex-direction:column;gap:var(--space-1)}.settings-tab{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);font-size:.875rem;font-weight:500;color:var(--text-secondary);background:none;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:left}.settings-tab .tab-arrow{margin-left:auto;opacity:0;transition:opacity var(--transition-fast)}.settings-tab:hover{background:var(--bg-hover);color:var(--text-primary)}.settings-tab:hover .tab-arrow{opacity:.5}.settings-tab.active{background:var(--accent-primary-light);color:var(--accent-primary)}.settings-tab.active .tab-arrow{opacity:1;color:var(--accent-primary)}.settings-content{min-width:0}.settings-section h3{font-size:1.125rem;font-weight:600;margin-bottom:var(--space-2)}.section-description{font-size:.8125rem;color:var(--text-tertiary);margin-bottom:var(--space-5)}.setting-card{padding:var(--space-5);margin-bottom:var(--space-4)}.setting-card-header{display:flex;align-items:center;gap:var(--space-2);font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-color)}.setting-row{display:grid;grid-template-columns:140px 1fr;gap:var(--space-3);align-items:center;padding:var(--space-2) 0}.setting-row label{font-size:.8125rem;font-weight:500;color:var(--text-tertiary)}.setting-value{font-size:.875rem;color:var(--text-primary)}.setting-value.mono{font-family:var(--font-mono, monospace);font-size:.8125rem;color:var(--text-secondary)}.setting-input-group{display:flex;gap:var(--space-2);align-items:center}.setting-input-group .input{flex:1}.setting-error{font-size:.75rem;color:var(--accent-error);grid-column:1 / -1;padding:var(--space-2) 0}.setting-success{font-size:.75rem;color:var(--accent-success);grid-column:1 / -1;padding:var(--space-2) 0}.setting-hint{font-size:.8125rem;color:var(--text-tertiary);margin:0 0 var(--space-4);line-height:1.45}.settings-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.settings-modal-inner{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);min-width:320px;max-width:440px;box-shadow:0 20px 50px #00000059}.settings-modal-inner h3{margin:0 0 var(--space-4);font-size:1.0625rem;font-weight:600}.btn-sm{padding:var(--space-2) var(--space-3)!important;font-size:.8125rem!important;gap:var(--space-1)!important}.plan-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:10px;font-size:.75rem;font-weight:600;text-transform:capitalize}.plan-free{background:var(--bg-secondary);color:var(--text-secondary)}.plan-pro{background:var(--accent-primary-light);color:var(--accent-primary)}.plan-enterprise{background:#a855f71f;color:#a855f7}.usage-inline{display:flex;align-items:center;gap:var(--space-3)}.usage-bar-sm{flex:1;max-width:200px;height:6px;background:var(--bg-secondary);border-radius:3px;overflow:hidden}.usage-fill-sm{height:100%;background:var(--accent-primary);border-radius:3px;transition:width .4s ease}.connection-badge{display:inline-flex;align-items:center;gap:var(--space-1);margin-left:auto;font-size:.75rem;font-weight:500;padding:2px 8px;border-radius:10px}.connection-badge.connected{color:var(--accent-success);background:#22c55e1a}.connection-badge.disconnected{color:var(--text-muted);background:var(--bg-secondary)}.github-connect-form{display:flex;flex-direction:column;gap:0}.github-account-confirmed{display:inline-flex;align-items:center;gap:var(--space-2);font-size:.875rem;color:var(--accent-success)}.github-account-confirmed strong{color:var(--text-primary)}.setting-hint code{font-family:var(--font-mono, monospace);font-size:.8125rem;background:var(--bg-secondary);padding:1px 5px;border-radius:4px;color:var(--text-primary)}.features-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-4)}.feature-card{padding:var(--space-4);position:relative;transition:all var(--transition-fast)}.feature-card.feature-disabled{opacity:.5}.feature-status{margin-bottom:var(--space-3)}.feature-on{color:var(--accent-success)}.feature-off{color:var(--text-muted)}.feature-card h4{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-1)}.feature-card p{font-size:.75rem;color:var(--text-tertiary);margin:0;line-height:1.4}.settings-section .setting-row .input{max-width:320px}@media (max-width: 768px){.settings-layout{grid-template-columns:1fr}.settings-sidebar{flex-direction:row;overflow-x:auto;gap:var(--space-1);padding-bottom:var(--space-2);border-bottom:1px solid var(--border-color);margin-bottom:var(--space-4)}.settings-tab{white-space:nowrap;padding:var(--space-2) var(--space-3);border-radius:var(--radius-xl);font-size:.8125rem}.settings-tab .tab-arrow{display:none}.setting-row{grid-template-columns:1fr;gap:var(--space-1)}.features-grid{grid-template-columns:1fr}.settings-section .setting-row .input{max-width:100%}}.users-settings-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-4)}.users-settings-header h2{margin:0}.users-org-subtitle{width:100%;margin:var(--space-1) 0 0;font-size:.875rem;color:var(--text-tertiary)}.users-header-actions{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2)}.users-add-header-btn{display:inline-flex;align-items:center;gap:var(--space-2)}.users-members-card{margin-top:0}.users-field-label-span{display:block;font-size:.8125rem;font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-2)}.users-project-checklist-embedded{max-height:220px;overflow-y:auto;border-radius:var(--radius-md);border:1px solid var(--border-subtle);padding:var(--space-2);background:var(--bg-tertiary)}.users-project-check-row-dim{opacity:.55}.users-send-invite-row{display:flex;flex-direction:row;align-items:center;gap:var(--space-3);margin:0;width:100%;box-sizing:border-box;cursor:pointer;-webkit-user-select:none;user-select:none}.users-send-invite-row:focus-within{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #3b82f626}.users-send-invite-checkbox{margin:0;flex-shrink:0;width:18px;height:18px;cursor:pointer;accent-color:var(--accent-primary)}.users-send-invite-inline-hint{font-size:.8125rem;color:var(--text-tertiary);line-height:1.35;flex:1;min-width:0}.users-project-cell{font-size:.875rem;color:var(--text-secondary)}.users-row-actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-2);flex-wrap:nowrap}.users-icon-btn{padding:var(--space-2);min-width:36px;display:inline-flex;align-items:center;justify-content:center}.users-edit-modal-overlay.modal-overlay{z-index:5000;align-items:center;justify-content:center;padding:var(--space-4);overflow-y:auto}.users-edit-modal.modal{max-width:min(920px,96vw);width:100%}.users-edit-modal.glass-card,.users-edit-modal.glass-card:hover{transform:none;box-shadow:var(--shadow-xl),0 0 0 1px #6366f11a}.users-edit-modal-body{padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:var(--space-4);overflow-y:auto;max-height:min(72vh,720px)}.users-edit-modal-body.users-edit-modal-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-4) var(--space-5);align-content:start}.users-field-span-full{grid-column:1 / -1}.users-edit-modal-inline-row{grid-column:1 / -1;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-4) var(--space-5);align-items:stretch}.users-edit-modal-inline-row>.users-field{display:flex;flex-direction:column;min-width:0}.users-edit-modal-inline-row>.users-field>select.input,.users-edit-modal-inline-row>.users-field>.users-send-invite-row{min-height:2.75rem;box-sizing:border-box}.users-edit-modal .users-project-checklist-embedded{max-height:min(280px,34vh)}.users-edit-modal-inline-row--3cols{grid-template-columns:repeat(2,minmax(0,1fr))}@media (min-width: 720px){.users-edit-modal-inline-row--3cols{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (max-width: 640px){.users-edit-modal-body.users-edit-modal-form-grid,.users-edit-modal-inline-row{grid-template-columns:1fr}}.users-card-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-lg);background:var(--accent-primary-light);color:var(--accent-primary)}.users-invite-intro{font-size:.8125rem;color:var(--text-tertiary);margin:calc(-1 * var(--space-2)) 0 var(--space-4);line-height:1.45}.users-form-stack{display:flex;flex-direction:column;gap:var(--space-4)}.users-field>label:not(.input){display:block;font-size:.8125rem;font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-1)}.users-field-full{width:100%}.users-password-row{display:flex;flex-wrap:wrap;align-items:stretch;gap:var(--space-2)}.users-password-input{flex:1 1 160px;min-width:0;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.8125rem;letter-spacing:.02em}.users-password-actions{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center}.users-password-actions .btn{white-space:nowrap}.users-projects-select{width:100%;min-height:92px;font-size:.8125rem}.users-assign-hint{font-size:.75rem;color:var(--text-tertiary);margin:var(--space-1) 0 0;line-height:1.35}.users-invite-opt{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-lg);background:var(--bg-tertiary);border:1px solid var(--border-color)}.users-invite-opt input[type=checkbox]{margin-top:4px;width:16px;height:16px;flex-shrink:0}.users-invite-opt label{font-size:.8125rem;margin:0;cursor:pointer}.users-invite-opt-hint{display:block;font-weight:400;font-size:.75rem;color:var(--text-tertiary);margin-top:var(--space-1)}.users-actions{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-1)}.users-banner{font-size:.8125rem;padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);margin-top:var(--space-3);line-height:1.4}.users-banner-success{background:#22c55e1f;border:1px solid rgba(34,197,94,.35);color:var(--accent-success)}.users-banner-warning{background:#f59e0b1a;border:1px solid rgba(245,158,11,.35);color:var(--accent-warning)}.users-banner-danger{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--accent-error)}.users-table-scroll{margin-top:var(--space-2);overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border-color)}.users-table{width:100%;border-collapse:collapse;font-size:.875rem}.users-col-actions{text-align:right;width:1%}.users-table thead th{text-align:left;padding:var(--space-3) var(--space-4);background:var(--bg-tertiary);color:var(--text-secondary);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.02em;border-bottom:1px solid var(--border-color)}.users-table tbody td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle);vertical-align:middle}.users-table tbody tr:last-child td{border-bottom:none}.users-email-cell strong{display:block;font-weight:500;color:var(--text-primary)}.users-email-realname{display:block;margin-top:2px;font-size:.8125rem;font-weight:400;color:var(--text-secondary)}.users-email-muted{display:block;margin-top:2px;font-size:.75rem;color:var(--text-tertiary);font-family:var(--font-mono, ui-monospace, monospace)}.users-select{font-size:.8125rem}.users-empty{padding:var(--space-8);text-align:center;color:var(--text-tertiary);font-size:.875rem}.users-loading-chip{font-size:.75rem;padding:var(--space-1) var(--space-3);border-radius:999px;background:var(--bg-tertiary);color:var(--text-secondary);margin-left:auto}.users-delete{opacity:.85}.users-delete:hover{opacity:1}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-4);animation:fadeIn .2s ease-out}.modal{width:100%;max-width:500px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease-out}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--text-tertiary);transition:all var(--transition-fast);flex-shrink:0}.modal-close:hover{background:var(--bg-elevated);color:var(--text-primary)}.users-project-modal-overlay{z-index:1100}.users-project-modal{max-width:440px}.users-project-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-color)}.users-project-modal-title-wrap{display:flex;gap:var(--space-3);min-width:0}.users-project-modal-title-icon{flex-shrink:0;margin-top:2px;color:var(--accent-primary)}.users-project-modal-head h2{margin:0;font-size:1.0625rem;font-weight:600;line-height:1.3}.users-project-modal-desc{margin:var(--space-2) 0 0;font-size:.8125rem;font-weight:400;color:var(--text-tertiary);line-height:1.45}.users-project-modal-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-bottom:1px solid var(--border-subtle);background:var(--bg-tertiary)}.users-project-modal-count{margin-left:auto;font-size:.75rem;font-weight:500;color:var(--text-secondary)}.users-project-modal-body{padding:var(--space-4) var(--space-5);overflow-y:auto;flex:1;min-height:0}.users-project-modal-empty{margin:0;text-align:center;padding:var(--space-4) 0}.users-project-checklist{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.users-project-checklist li{margin:0}.users-project-checklist .users-project-check-row{display:flex;align-items:flex-start;gap:var(--space-5);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);cursor:pointer;font-size:.875rem;color:var(--text-primary);transition:background var(--transition-fast)}.users-project-checklist .users-project-check-row:hover{background:var(--bg-tertiary)}.users-project-checklist .users-project-check-row input[type=checkbox]{margin-top:3px;width:16px;height:16px;flex-shrink:0}.users-project-checklist .users-project-check-row span{min-width:0;line-height:1.4}.users-project-pick-label{display:flex;flex-direction:column;align-items:flex-start;gap:2px;min-width:0}.users-project-pick-primary{font-weight:500;color:var(--text-primary);line-height:1.35}.users-project-pick-meta{font-size:.75rem;font-weight:400;color:var(--text-tertiary);line-height:1.35;word-break:break-word}.users-project-modal-foot{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-top:1px solid var(--border-color);flex-shrink:0}.users-project-summary{font-size:.75rem;font-weight:500}.users-project-summary.muted{color:var(--text-tertiary)}.users-project-summary.warn{color:var(--accent-warning)}.users-project-picker-row{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);margin-top:var(--space-2)}.users-project-picker-row.invite{margin-top:var(--space-3)}.users-choose-projects-btn{flex-shrink:0}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.support-page{display:flex;flex-direction:column;gap:var(--space-6)}.support-header{display:flex;align-items:center;justify-content:space-between}.support-header h2{font-size:1.25rem;font-weight:700}.support-filters{display:flex;gap:var(--space-3);flex-wrap:wrap}.support-filters select,.support-filters input{padding:6px 12px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);font-size:.8125rem}.ticket-list{display:flex;flex-direction:column;gap:var(--space-3)}.ticket-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:border-color .15s,box-shadow .15s}.ticket-card:hover{border-color:var(--accent-primary);box-shadow:0 0 0 1px var(--accent-primary)}.ticket-priority{width:4px;align-self:stretch;border-radius:2px;flex-shrink:0}.ticket-priority.urgent{background:#ef4444}.ticket-priority.high{background:#f97316}.ticket-priority.normal{background:#6366f1}.ticket-priority.low{background:#94a3b8}.ticket-info{flex:1;min-width:0}.ticket-info h4{font-size:.875rem;font-weight:600;margin:0 0 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ticket-meta{display:flex;gap:var(--space-3);font-size:.75rem;color:var(--text-secondary)}.ticket-badges{display:flex;gap:var(--space-2);align-items:center;flex-shrink:0}.ticket-badge{font-size:.6875rem;font-weight:600;padding:2px 8px;border-radius:var(--radius-full);text-transform:capitalize}.ticket-badge.open{background:#22c55e26;color:#22c55e}.ticket-badge.in_progress{background:#6366f126;color:#6366f1}.ticket-badge.resolved{background:#3b82f626;color:#3b82f6}.ticket-badge.closed{background:#94a3b826;color:#94a3b8}.ticket-reply-count{display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--text-secondary)}.ticket-detail{display:flex;flex-direction:column;gap:var(--space-5)}.ticket-detail-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4)}.ticket-detail-header h3{font-size:1.125rem;font-weight:700;margin:0}.ticket-detail-meta{display:flex;gap:var(--space-3);flex-wrap:wrap;font-size:.8125rem;color:var(--text-secondary);margin-top:var(--space-2)}.ticket-description{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);font-size:.875rem;line-height:1.65;white-space:pre-wrap}.reply-thread{display:flex;flex-direction:column;gap:var(--space-3)}.reply-thread-title{font-size:.8125rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.reply-item{display:flex;flex-direction:column;padding:var(--space-4);border-radius:var(--radius-lg);font-size:.875rem;line-height:1.6}.reply-item.tenant{background:var(--bg-secondary);border:1px solid var(--border);margin-right:var(--space-8)}.reply-item.admin{background:#6366f114;border:1px solid rgba(99,102,241,.2);margin-left:var(--space-8)}.reply-author{display:flex;align-items:center;justify-content:space-between;font-size:.75rem;font-weight:600;margin-bottom:var(--space-2)}.reply-author .author-label{color:var(--text-secondary)}.reply-author .admin-label{color:#6366f1}.reply-body{white-space:pre-wrap}.reply-time{font-size:.6875rem;color:var(--text-tertiary)}.reply-composer{display:flex;flex-direction:column;gap:var(--space-3)}.reply-composer textarea{width:100%;min-height:100px;padding:var(--space-3);border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;font-family:inherit;resize:vertical}.reply-composer textarea:focus{outline:none;border-color:var(--accent-primary)}.reply-composer-actions{display:flex;justify-content:flex-end;gap:var(--space-2)}.create-ticket-form{display:flex;flex-direction:column;gap:var(--space-4)}.create-ticket-form .form-row{display:flex;flex-direction:column;gap:var(--space-1)}.create-ticket-form label{font-size:.8125rem;font-weight:600;color:var(--text-secondary)}.create-ticket-form input,.create-ticket-form select,.create-ticket-form textarea{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;font-family:inherit}.create-ticket-form textarea{min-height:120px;resize:vertical}.create-ticket-form input:focus,.create-ticket-form select:focus,.create-ticket-form textarea:focus{outline:none;border-color:var(--accent-primary)}.form-actions{display:flex;justify-content:flex-end;gap:var(--space-2);margin-top:var(--space-2)}.empty-tickets{text-align:center;padding:var(--space-12);color:var(--text-secondary)}.empty-tickets p{margin:var(--space-2) 0}.howto-page{max-width:1000px}.howto-header{margin-bottom:var(--space-8)}.howto-header h2{font-size:1.5rem;font-weight:700;margin-bottom:var(--space-2)}.howto-header p{color:var(--text-secondary);font-size:.925rem}.howto-section{margin-bottom:var(--space-8)}.howto-section-title{display:flex;align-items:center;gap:var(--space-3);font-size:1.15rem;font-weight:700;margin-bottom:var(--space-4);color:var(--text-primary)}.howto-section-title .section-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);flex-shrink:0}.section-icon.ecs{background:#6366f126;color:var(--accent-primary)}.section-icon.serverless{background:#10b98126;color:var(--accent-success)}.section-icon.frontend{background:#f59e0b26;color:#f59e0b}.section-icon.general{background:#8b5cf626;color:#8b5cf6}.section-icon.db{background:#14b8a626;color:#14b8a6}.section-icon.github{background:#6366f126;color:var(--accent-primary)}.howto-steps{display:flex;flex-direction:column;gap:var(--space-4)}.howto-step{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden}.howto-step-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);cursor:pointer;transition:background var(--transition-fast)}.howto-step-header:hover{background:var(--bg-hover)}.howto-step-number{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background:var(--accent-primary-light);color:var(--accent-primary);font-size:.8rem;font-weight:700;flex-shrink:0}.howto-step-title{font-size:.925rem;font-weight:600;color:var(--text-primary);flex:1}.howto-step-toggle{color:var(--text-muted);transition:transform var(--transition-fast)}.howto-step-toggle.open{transform:rotate(180deg)}.howto-step-content{padding:0 var(--space-4) var(--space-4);padding-left:calc(var(--space-4) + 28px + var(--space-3));color:var(--text-secondary);font-size:.875rem;line-height:1.7}.howto-step-content p{margin-bottom:var(--space-3)}.howto-step-content ul{padding-left:var(--space-5);margin-bottom:var(--space-3)}.howto-step-content li{margin-bottom:var(--space-1)}.howto-code{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);font-family:var(--font-mono);font-size:.8rem;line-height:1.6;overflow-x:auto;margin:var(--space-3) 0;color:var(--text-primary);white-space:pre}.howto-code-inline{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1px 6px;font-family:var(--font-mono);font-size:.8rem;color:var(--accent-primary)}.howto-callout{display:flex;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:#6366f114;border:1px solid rgba(99,102,241,.2);border-radius:var(--radius-lg);font-size:.825rem;color:var(--text-secondary);margin:var(--space-3) 0;line-height:1.6}.howto-callout.warning{background:#f59e0b14;border-color:#f59e0b33}.howto-callout svg{flex-shrink:0;margin-top:2px;color:var(--accent-primary)}.howto-callout.warning svg{color:#f59e0b}.howto-quick-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-3);margin-bottom:var(--space-8)}.howto-quick-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-fast);text-align:left}.howto-quick-link:hover{border-color:var(--accent-primary);background:var(--bg-hover);transform:translateY(-1px)}.howto-quick-link-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);flex-shrink:0}.howto-quick-link-text{display:flex;flex-direction:column;gap:2px}.howto-quick-link-text strong{font-size:.875rem;color:var(--text-primary)}.howto-quick-link-text span{font-size:.75rem;color:var(--text-muted)}@media (max-width: 768px){.howto-step-content{padding-left:var(--space-4)}.howto-quick-links{grid-template-columns:1fr}}.legal-page{min-height:100vh;background:var(--bg-primary);color:var(--text-primary);padding:2rem 1.5rem 4rem}.legal-header{max-width:720px;margin:0 auto 2.5rem;display:flex;align-items:center;justify-content:space-between}.legal-back{display:inline-flex;align-items:center;gap:.4rem;color:var(--text-muted);text-decoration:none;font-size:.875rem;transition:color .15s}.legal-back:hover{color:var(--text-primary)}.legal-content{max-width:720px;margin:0 auto}.legal-content h1{font-size:2rem;font-weight:700;margin-bottom:.5rem;color:var(--text-primary)}.legal-updated{font-size:.85rem;color:var(--text-muted);margin-bottom:2.5rem}.legal-content section{margin-bottom:2rem}.legal-content h2{font-size:1.1rem;font-weight:600;margin-bottom:.75rem;color:var(--text-primary)}.legal-content p{font-size:.9rem;line-height:1.7;color:var(--text-secondary);margin-bottom:.75rem}.legal-content ul{padding-left:1.5rem;margin-bottom:.75rem}.legal-content ul li{font-size:.9rem;line-height:1.7;color:var(--text-secondary);margin-bottom:.25rem}.legal-content a{color:var(--accent-primary, #7C3AED);text-decoration:underline}.legal-content a:hover{opacity:.8}:root{--bg-primary: #1F252B;--bg-secondary: #232B33;--bg-tertiary: #263038;--bg-elevated: #2C353D;--bg-hover: #333D46;--glass-bg: rgba(255, 255, 255, .02);--glass-bg-hover: rgba(255, 255, 255, .05);--glass-border: rgba(255, 255, 255, .06);--glass-border-hover: rgba(255, 255, 255, .12);--glass-hover: rgba(255, 255, 255, .08);--text-primary: #ffffff;--text-secondary: #b4b4b8;--text-tertiary: #7c7c82;--text-muted: #52525b;--accent-primary: #7000FF;--accent-primary-hover: #5c00d4;--accent-primary-light: rgba(112, 0, 255, .12);--accent-success: #22c55e;--accent-success-light: rgba(34, 197, 94, .15);--accent-warning: #f59e0b;--accent-warning-light: rgba(245, 158, 11, .15);--accent-error: #ef4444;--accent-error-light: rgba(239, 68, 68, .15);--accent-info: #06b6d4;--accent-info-light: rgba(6, 182, 212, .15);--accent-purple: #a855f7;--accent-pink: #ec4899;--accent-orange: #f97316;--gradient-primary: linear-gradient(135deg, #7000FF 0%, #8b2fff 50%, #a855f7 100%);--gradient-success: linear-gradient(135deg, #22c55e 0%, #10b981 100%);--gradient-warning: linear-gradient(135deg, #f59e0b 0%, #f97316 100%);--gradient-error: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);--gradient-glass: linear-gradient(135deg, rgba(255,255,255,.08) 0%, rgba(255,255,255,.02) 100%);--gradient-shine: linear-gradient(90deg, transparent 0%, rgba(255,255,255,.1) 50%, transparent 100%);--border-color: #38434D;--border-light: #4A5560;--border-subtle: rgba(255, 255, 255, .05);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .5), 0 2px 4px -2px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5), 0 4px 6px -4px rgba(0, 0, 0, .3);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .5), 0 8px 10px -6px rgba(0, 0, 0, .3);--shadow-glow: 0 0 40px rgba(112, 0, 255, .2);--shadow-glow-success: 0 0 40px rgba(34, 197, 94, .2);--shadow-glow-error: 0 0 40px rgba(239, 68, 68, .2);--shadow-inner: inset 0 2px 4px rgba(0, 0, 0, .3);--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 20px;--radius-3xl: 24px;--radius-full: 9999px;--font-sans: "Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", Consolas, monospace;--sidebar-width: 280px;--sidebar-collapsed-width: 72px;--header-height: 68px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--transition-slower: .5s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .4s cubic-bezier(.34, 1.56, .64, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.5;min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none}input,textarea,select{font-family:inherit;font-size:inherit}.glass{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border)}.glass-card{margin-top:5px;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-xl);transition:all var(--transition-base);position:relative;overflow:hidden}.glass-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent)}.glass-card:hover{background:var(--glass-bg-hover);border-color:var(--glass-border-hover);box-shadow:var(--shadow-lg),0 0 0 1px #6366f11a;transform:translateY(-2px)}.glass-card-interactive{cursor:pointer}.glass-card-interactive:hover{transform:translateY(-4px) scale(1.01);box-shadow:var(--shadow-xl),0 0 0 1px #6366f126,var(--shadow-glow)}.glass-card-interactive:active{transform:translateY(-2px) scale(.99)}.card-shine{position:relative;overflow:hidden}.card-shine:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:var(--gradient-shine);transform:rotate(45deg) translate(-100%);transition:transform .6s ease}.card-shine:hover:after{transform:rotate(45deg) translate(100%)}.gradient-text{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.gradient-text-success{background:var(--gradient-success);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);font-size:.875rem;font-weight:500;border-radius:var(--radius-lg);transition:all var(--transition-base);position:relative;overflow:hidden;white-space:nowrap}.btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.1) 0%,transparent 100%);opacity:0;transition:opacity var(--transition-fast)}.btn:hover:before{opacity:1}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-md),0 0 0 1px #7000ff4d;border:none}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),var(--shadow-glow),0 0 0 1px #7000ff66}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary{background:var(--bg-elevated);border:1px solid var(--border-color);color:var(--text-primary)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-light);transform:translateY(-1px)}.btn-ghost{color:var(--text-secondary);background:transparent}.btn-ghost:hover{background:var(--bg-elevated);color:var(--text-primary);transform:translateY(-1px)}.btn-danger{background:var(--accent-error);color:#fff;box-shadow:0 0 0 1px #ef44444d}.btn-danger:hover{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:var(--shadow-glow-error);transform:translateY(-2px)}.btn-outline{background:transparent;border:1px solid var(--border-color);color:var(--text-primary)}.btn-outline:hover{background:var(--glass-bg-hover);border-color:var(--glass-border-hover);color:var(--text-primary)}.btn-glass{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);color:var(--text-primary)}.btn-glass:hover{background:var(--glass-bg-hover);border-color:var(--glass-border-hover)}.btn-sm{padding:var(--space-2) var(--space-3);font-size:.8125rem;border-radius:var(--radius-md)}.btn-lg{padding:var(--space-4) var(--space-6);font-size:1rem;border-radius:var(--radius-xl)}.btn-icon{padding:var(--space-2);border-radius:var(--radius-md)}.btn-icon-lg{padding:var(--space-3);border-radius:var(--radius-lg)}.input{width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;transition:all var(--transition-fast)}.input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #3b82f626}.input::placeholder{color:var(--text-muted)}.input-label{display:block;margin-bottom:var(--space-2);font-size:.875rem;font-weight:500;color:var(--text-secondary)}.input-group{margin-bottom:var(--space-4)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:.75rem;font-weight:500;border-radius:var(--radius-full)}.badge-success{background:#22c55e26;color:var(--accent-success)}.badge-warning{background:#f59e0b26;color:var(--accent-warning)}.badge-error{background:#ef444426;color:var(--accent-error)}.badge-info{background:#06b6d426;color:var(--accent-info)}.badge-neutral{background:var(--bg-elevated);color:var(--text-secondary)}.card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-6)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.card-title{font-size:1.125rem;font-weight:600}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:var(--space-3) var(--space-4);text-align:left;border-bottom:1px solid var(--border-color)}.table th{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);background:var(--bg-tertiary)}.table tr:hover td{background:var(--bg-elevated)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes pulse-ring{0%{transform:scale(.8);opacity:1}to{transform:scale(1.3);opacity:0}}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes glow{0%,to{box-shadow:0 0 20px #7000ff4d}50%{box-shadow:0 0 40px #7000ff80}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.animate-fadeIn{animation:fadeIn var(--transition-base) forwards}.animate-fadeIn-scale{animation:fadeInScale var(--transition-slow) cubic-bezier(.34,1.56,.64,1) forwards}.animate-slideUp{animation:slideUp var(--transition-slow) cubic-bezier(.16,1,.3,1) forwards}.animate-slideDown{animation:slideDown var(--transition-slow) cubic-bezier(.16,1,.3,1) forwards}.animate-slideInRight{animation:slideInRight var(--transition-slow) cubic-bezier(.16,1,.3,1) forwards}.animate-slideInLeft{animation:slideInLeft var(--transition-slow) cubic-bezier(.16,1,.3,1) forwards}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.animate-pulse-ring{animation:pulse-ring 1.5s cubic-bezier(.215,.61,.355,1) infinite}.animate-spin{animation:spin 1s linear infinite}.animate-bounce{animation:bounce 2s ease-in-out infinite}.animate-shimmer{animation:shimmer 2s linear infinite;background:linear-gradient(90deg,transparent,rgba(255,255,255,.05),transparent);background-size:1000px 100%}.animate-float{animation:float 3s ease-in-out infinite}.animate-glow{animation:glow 2s ease-in-out infinite}.animate-shake{animation:shake .5s ease-in-out}.stagger-1{animation-delay:.05s}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}.stagger-6{animation-delay:.3s}.stagger-7{animation-delay:.35s}.stagger-8{animation-delay:.4s}.animate-on-mount{opacity:0}.animate-on-mount.animate-fadeIn,.animate-on-mount.animate-slideUp,.animate-on-mount.animate-slideInRight{opacity:1}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.skeleton{background:linear-gradient(90deg,var(--bg-elevated) 0%,var(--bg-hover) 25%,var(--bg-elevated) 50%,var(--bg-hover) 75%,var(--bg-elevated) 100%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:var(--radius-md);position:relative;overflow:hidden}.skeleton:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.03),transparent);animation:shimmer 2s linear infinite}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6)}.skeleton-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-4)}.skeleton-avatar{width:48px;height:48px;border-radius:var(--radius-lg)}.skeleton-text{height:16px;border-radius:var(--radius-sm)}.skeleton-text-sm{height:12px;border-radius:var(--radius-sm);width:60%}.skeleton-circle{border-radius:var(--radius-full)}.loading-pulse{animation:pulse 1.5s ease-in-out infinite}.spinner{width:24px;height:24px;border:2px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}.spinner-sm{width:16px;height:16px;border-width:1.5px}.spinner-lg{width:32px;height:32px;border-width:3px}.spinner-primary{border-top-color:var(--accent-primary)}.spinner-success{border-top-color:var(--accent-success)}.spinner-white{border-color:#fff3;border-top-color:#fff}
