@import "https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=JetBrains+Mono:wght@400;500;600&display=swap";.auth-container{min-height:100vh;padding:var(--spacing-lg);background:var(--bg-primary);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.auth-background{z-index:0;position:absolute;inset:0}.auth-background:before{content:"";background:radial-gradient(80% 60% at 20% 30%,#7c3aed2e 0%,#0000 60%),radial-gradient(60% 50% at 80% 70%,#06b6d41f 0%,#0000 60%);animation:8s ease-in-out infinite alternate meshFloat;position:absolute;inset:0}.auth-background:after{content:"";background-image:linear-gradient(#9646ff0a 1px,#0000 1px),linear-gradient(90deg,#9646ff0a 1px,#0000 1px);background-size:48px 48px;position:absolute;inset:0}.auth-content{z-index:1;align-items:center;gap:60px;width:100%;max-width:900px;display:flex;position:relative}.auth-card{border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(24px);background:#0e0418e6;border:1px solid #9646ff2e;flex:1;max-width:420px;padding:40px;box-shadow:0 24px 64px #00000080,0 0 0 1px #06b6d40d}.auth-card--wide{max-width:560px}.auth-header{text-align:center;margin-bottom:32px}.logo-large{align-items:center;gap:10px;margin-bottom:12px;display:inline-flex}.logo-icon-large{background:var(--gradient-brand);border-radius:var(--radius-sm);color:#fff;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.logo-text-large{background:var(--gradient-brand-text);-webkit-text-fill-color:transparent;letter-spacing:-.01em;-webkit-background-clip:text;background-clip:text;font-size:22px;font-weight:700}.auth-subtitle{color:var(--text-muted);font-size:14px}.auth-form{flex-direction:column;gap:18px;display:flex}.error-banner{border-radius:var(--radius-sm);color:var(--accent-red);background:#ef44441a;border:1px solid #ef44444d;align-items:center;gap:8px;padding:12px 14px;font-size:14px;display:flex}.error-icon{flex-shrink:0;font-size:16px}.form-group{flex-direction:column;gap:6px;display:flex}.form-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;font-family:var(--font-sans);width:100%;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:11px 14px}.form-input:focus{border-color:var(--accent-cyan);outline:none;box-shadow:0 0 0 3px #06b6d426}.form-hint{color:var(--text-muted);font-size:12px}.pwd-requirements{border:1px solid var(--border);border-radius:var(--radius-sm);background:#00000040;flex-direction:column;gap:5px;padding:10px 12px;animation:.15s fadeIn;display:flex}.pwd-req-item{font-family:var(--font-mono);color:var(--text-muted);align-items:center;gap:8px;font-size:11px;transition:color .2s;display:flex}.pwd-req-item.met{color:var(--accent-green)}.pwd-req-item.unmet{color:var(--text-muted)}.pwd-req-icon{text-align:center;flex-shrink:0;width:14px;font-size:12px}.auth-footer{text-align:center;margin-top:24px}.auth-footer-text{color:var(--text-muted);font-size:14px}.auth-link{color:var(--accent-cyan);font-weight:500;text-decoration:none}.auth-link:hover{text-decoration:underline}.auth-note{font-family:var(--font-mono);color:var(--text-muted);justify-content:center;align-items:center;gap:8px;margin-top:20px;font-size:11px;display:flex}.terminal-prompt{color:var(--accent-cyan)}.auth-features{flex-direction:column;gap:28px;display:flex}.feature-item{align-items:flex-start;gap:14px;display:flex}.feature-icon-wrap{border-radius:var(--radius-md);width:40px;height:40px;color:var(--accent-violet);background:#7c3aed1f;border:1px solid #7c3aed40;flex-shrink:0;justify-content:center;align-items:center;display:flex}.feature-icon-wrap.cyan{color:var(--accent-cyan);background:#06b6d41a;border-color:#06b6d440}.feature-icon-wrap.green{color:var(--accent-green);background:#10b9811a;border-color:#10b98140}.feature-icon{font-size:24px;line-height:1}.feature-title{color:var(--text-primary);margin:0 0 4px;font-size:15px;font-weight:700}.feature-description{color:var(--text-secondary);margin:0;font-size:13px;line-height:1.5}@media (width<=768px){.auth-content{flex-direction:column;gap:32px}.auth-features{display:none}.auth-card{padding:28px 24px}}.project-card--slim{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);padding:var(--spacing-lg);transition:border-color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);cursor:pointer;text-decoration:none;display:block;position:relative;overflow:hidden}.project-card--slim:hover{border-color:#06b6d44d;box-shadow:0 0 0 1px #06b6d41a,0 8px 32px #0000004d}.project-card--slim.running{border-left:2px solid #10b98180}.project-header{margin-bottom:var(--spacing-sm);justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.project-info{flex:1;min-width:0}.project-name{font-family:var(--font-mono);color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;margin-bottom:3px;font-size:15px;font-weight:700;overflow:hidden}.project-url{font-family:var(--font-mono);color:var(--accent-cyan);text-overflow:ellipsis;white-space:nowrap;opacity:.8;font-size:11px;display:block;overflow:hidden}.status-badge{font-family:var(--font-mono);border-radius:var(--radius-full);white-space:nowrap;flex-shrink:0;align-items:center;gap:5px;padding:3px 8px;font-size:10px;font-weight:600;display:inline-flex}.project-meta--slim{gap:var(--spacing-lg);padding-top:var(--spacing-sm);border-top:1px solid var(--border);flex-wrap:wrap;display:flex}.meta-item{flex-direction:column;gap:2px;min-width:0;display:flex}.meta-label{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;font-size:9px}.meta-value{font-family:var(--font-mono);color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.framework-badge{border-radius:var(--radius-full);font-family:var(--font-mono);color:var(--accent-cyan);white-space:nowrap;letter-spacing:.02em;background:#06b6d412;border:1px solid #06b6d42e;align-items:center;padding:1px 6px;font-size:9px;display:inline-flex}.custom-domain-status-icon.status-active{color:var(--accent-green)}.custom-domain-status-icon.status-ssl_pending{color:var(--accent-cyan)}.custom-domain-status-icon.status-dns_pending,.custom-domain-status-icon.status-pending{color:var(--accent-amber)}.custom-domain-status-icon.status-failed{color:var(--accent-red)}.dashboard-container{max-width:1400px;padding:var(--spacing-xl);min-height:100vh;margin:0 auto;animation:.3s fadeIn}.stats-bar{margin-bottom:var(--spacing-2xl);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;display:grid}.stat-card{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);padding:20px var(--spacing-lg);transition:transform var(--transition-fast), box-shadow var(--transition-fast)}.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #7c3aed26}.stat-label{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;font-size:10px}.stat-value{font-family:var(--font-mono);color:var(--text-primary);font-size:32px;font-weight:700;line-height:1}.stats-card{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);padding:var(--spacing-lg) var(--spacing-xl);margin-bottom:var(--spacing-2xl)}.stats-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:14px;font-weight:600;font-family:var(--font-mono);margin:0 0 var(--spacing-lg)}.stats-grid{gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(140px,1fr));display:grid}.stat-item{align-items:center;gap:14px;display:flex}.stat-item-icon{border-radius:var(--radius-md);width:40px;height:40px;color:var(--stat-color,var(--accent-violet));background:#7c3aed1f;border:1px solid #7c3aed40;flex-shrink:0;justify-content:center;align-items:center;display:flex}.stat-item-value{font-family:var(--font-mono);color:var(--text-primary);font-size:28px;font-weight:700;line-height:1}.stat-item-label{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:4px;font-size:10px}.stats-loading{font-family:var(--font-mono);color:var(--text-muted);text-align:center;padding:20px 0;font-size:12px}.section-header{margin-bottom:var(--spacing-lg);justify-content:space-between;align-items:center;gap:var(--spacing-md);display:flex}.section-title{color:var(--text-primary);letter-spacing:-.01em;font-size:18px;font-weight:700}.projects-grid{columns:3;column-gap:20px}@media (width<=1100px){.projects-grid{columns:2}}@media (width<=700px){.projects-grid{columns:1}}.loading-state{text-align:center;padding:var(--spacing-2xl);background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}.loading-spinner{border:2px solid var(--border);border-top-color:var(--accent-cyan);width:40px;height:40px;margin:0 auto var(--spacing-md);border-radius:50%;animation:.8s linear infinite spin}.error-state{text-align:center;padding:var(--spacing-2xl);border-radius:var(--radius-lg);background:#ef44440d;border:1px solid #ef444433}.error-state p{color:var(--accent-red);margin-bottom:var(--spacing-md)}.empty-state{text-align:center;padding:80px var(--spacing-xl)}.empty-icon{margin-bottom:var(--spacing-lg);opacity:.3;font-size:48px}.empty-description{color:var(--text-muted);margin-bottom:var(--spacing-lg);max-width:400px;margin-left:auto;margin-right:auto;font-size:14px}@media (width<=768px){.dashboard-container{padding:var(--spacing-md)}.stats-bar{grid-template-columns:1fr 1fr}.section-header{flex-direction:column;align-items:flex-start}}.create-project-page{max-width:1040px;padding:var(--spacing-xl);margin:0 auto;animation:.3s fadeIn}.create-project-grid{gap:var(--spacing-lg);grid-template-columns:1fr 340px;align-items:start;display:grid}.create-project-header{margin-bottom:var(--spacing-xl)}.back-button{font-family:var(--font-mono);color:var(--text-muted);cursor:pointer;margin-bottom:var(--spacing-sm);transition:color var(--transition-fast);background:0 0;border:none;align-items:center;gap:6px;padding:0;font-size:13px;display:inline-flex}.back-button:hover{color:var(--accent-cyan)}.create-project-title{color:var(--text-primary);letter-spacing:-.01em;margin:0 0 6px;font-size:28px;font-weight:700}.create-project-subtitle{color:var(--text-muted);margin:0;font-size:14px}.create-panel{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);padding:var(--spacing-xl);margin-bottom:var(--spacing-lg)}.panel-title{color:var(--text-primary);margin:0 0 var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border);align-items:center;gap:10px;font-size:15px;font-weight:700;display:flex}.form-group:last-child{margin-bottom:0}.form-label{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;align-items:center;gap:4px;font-size:11px;font-weight:600;display:inline-flex}.label-required{color:var(--accent-red);font-size:12px}.label-optional{color:var(--text-muted);text-transform:none;letter-spacing:0;font-size:11px;font-weight:400}.form-input,.form-select{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;font-family:var(--font-sans);width:100%;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:11px 14px}.form-input::placeholder{color:var(--text-muted)}.form-input:focus,.form-select:focus{border-color:var(--accent-cyan);outline:none;box-shadow:0 0 0 3px #06b6d426}.form-input:disabled{opacity:.5;cursor:not-allowed}.form-textarea{resize:vertical;min-height:80px;line-height:1.5}.form-hint{color:var(--text-muted);margin:0;font-size:12px}.hint-mono{font-family:var(--font-mono)}.detect-spinner{color:var(--text-muted);pointer-events:none;font-size:16px;animation:1s linear infinite spin;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.detect-result{border-radius:var(--radius-sm);align-items:center;gap:8px;margin-top:6px;padding:7px 10px;font-size:13px;display:flex}.detect-success{color:var(--accent-green);background:#10b98114;border:1px solid #10b98133}.detect-override{color:var(--accent-cyan);background:#06b6d414;border:1px solid #06b6d433}.detect-warn{color:var(--accent-amber);background:#f59e0b14;border:1px solid #f59e0b33}.detect-badge{font-family:var(--font-mono);flex:1;font-size:12px}.detect-override-btn{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast), background var(--transition-fast);white-space:nowrap;background:0 0;border:none;padding:2px 8px;font-size:12px}.detect-override-btn:hover{color:var(--text-primary);background:#ffffff0f}.detect-override-picker{margin-top:6px}.form-actions{gap:var(--spacing-sm);margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--border);justify-content:flex-end;display:flex}.alert-banner{border-radius:var(--radius-sm);margin-bottom:var(--spacing-md);align-items:center;gap:8px;padding:12px 16px;font-size:14px;display:flex}.deploy-dot{background:var(--accent-amber);border-radius:50%;width:8px;height:8px;animation:1.5s ease-in-out infinite pulse-green;display:inline-block}.build-output{border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--spacing-md);font-family:var(--font-mono);color:var(--accent-green);background:#120012e6;max-height:300px;font-size:12px;line-height:1.8;overflow-y:auto}.build-output::-webkit-scrollbar{width:6px}.build-output::-webkit-scrollbar-track{background:0 0}.build-output::-webkit-scrollbar-thumb{background:#7c3aed4d;border-radius:3px}.build-line{gap:8px;display:flex}.build-prompt{color:var(--text-muted);-webkit-user-select:none;user-select:none}.build-info{color:var(--accent-green)}.build-success{color:var(--accent-green);font-weight:600}.build-error{color:var(--accent-red)}.build-cursor{animation:1s step-end infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.info-panel{border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);padding:var(--spacing-xl);background:#06b6d408;border:1px solid #06b6d41f;position:sticky;top:24px}.info-panel-header{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid #06b6d41a}.info-panel-eyebrow{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--accent-cyan);margin-bottom:4px;font-size:10px;font-weight:600}.info-panel-title{color:var(--text-primary);font-size:16px;font-weight:700}.deploy-timeline{margin-bottom:var(--spacing-lg)}.timeline-item{gap:12px;display:flex}.timeline-track{flex-direction:column;flex-shrink:0;align-items:center;display:flex}.timeline-dot{width:26px;height:26px;font-family:var(--font-mono);color:var(--accent-cyan);background:#06b6d41a;border:1px solid #06b6d44d;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.timeline-line{background:#06b6d426;flex:1;width:1px;min-height:12px;margin:4px 0}.timeline-content{padding-bottom:var(--spacing-md)}.timeline-title{color:var(--text-primary);margin-bottom:3px;padding-top:3px;font-size:13px;font-weight:600}.timeline-desc{color:var(--text-muted);font-size:12px;line-height:1.6}.info-callout{border-radius:var(--radius-sm);background:#06b6d40f;border:1px solid #06b6d426;padding:12px 14px}.info-callout-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--accent-cyan);margin-bottom:6px;font-size:10px;font-weight:700}.info-callout-text{color:var(--text-muted);margin:0;font-size:12px;line-height:1.6}@media (width<=768px){.create-project-page{padding:var(--spacing-md)}.create-project-grid{grid-template-columns:1fr}.info-panel{position:static}}.history-container{max-width:1200px;padding:var(--spacing-xl);margin:0 auto;animation:.3s fadeIn}.history-header{margin-bottom:var(--spacing-xl);justify-content:space-between;align-items:center;gap:var(--spacing-md);display:flex}.history-back-btn{color:var(--text-muted);font-family:var(--font-sans);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;align-items:center;gap:8px;padding:0;font-size:14px;display:inline-flex}.history-back-btn:hover{color:var(--accent-cyan)}.history-title{color:var(--text-primary);letter-spacing:-.01em;margin:0;font-size:24px;font-weight:700}.history-table-wrap{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);overflow:hidden}.history-table{border-collapse:collapse;width:100%}.history-table th{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;text-align:left;border-bottom:1px solid var(--border);background:#1200124d;padding:14px 20px;font-size:10px;font-weight:600}.history-table td{color:var(--text-secondary);border-bottom:1px solid #b464ff0f;padding:13px 20px;font-size:13px}.history-table tr:last-child td{border-bottom:none}.history-table tr:hover td{background:#ffffff05}.deploy-status{font-family:var(--font-mono);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.06em;padding:3px 10px;font-size:10px;font-weight:600;display:inline-block}.status-success{color:var(--accent-green);background:#10b9811f;border:1px solid #10b9814d}.status-failed{color:var(--accent-red);background:#ef44441f;border:1px solid #ef44444d}.status-building{color:var(--accent-amber);background:#f59e0b1f;border:1px solid #f59e0b4d}.rollback-btn{font-family:var(--font-mono);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:4px 12px;font-size:11px}.rollback-btn:hover:not(:disabled){border-color:var(--accent-cyan);color:var(--accent-cyan);background:#06b6d414}.rollback-btn:disabled{opacity:.4;cursor:not-allowed}.confirm-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#120012cc;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.confirm-modal{border-radius:var(--radius-lg);padding:var(--spacing-xl);background:#160622f5;border:1px solid #b464ff33;width:90%;max-width:440px;box-shadow:0 24px 64px #0009}.confirm-modal h3{color:var(--text-primary);margin:0 0 var(--spacing-sm);font-size:18px;font-weight:700}.confirm-modal p{color:var(--text-muted);margin:0 0 var(--spacing-lg);font-size:14px;line-height:1.6}.confirm-actions{gap:var(--spacing-sm);justify-content:flex-end;display:flex}.btn-confirm{background:var(--gradient-brand);color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);border:none;padding:9px 20px;font-size:14px;font-weight:600}.btn-confirm:hover{background:var(--gradient-brand-hover);box-shadow:var(--glow-cyan)}.history-empty{text-align:center;color:var(--text-muted);padding:80px 20px}.history-loading{text-align:center;padding:var(--spacing-2xl);color:var(--text-muted);font-family:var(--font-mono);font-size:13px}@media (width<=768px){.history-container{padding:var(--spacing-md)}.history-table-wrap{overflow-x:auto}}.p32-panel{gap:var(--spacing-md);padding:var(--spacing-md);background:var(--glass-bg);border:var(--glass-border);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-md);flex-direction:column;animation:.3s fadeIn;display:flex}.p32-panel-title{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:var(--spacing-sm);font-size:11px;font-weight:500}.p32-panel-row{border-bottom:1px solid #9646ff0f;justify-content:space-between;align-items:center;padding:8px 0;font-size:13px;display:flex}.p32-panel-row:last-child{border-bottom:none}.p32-panel-key{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:11px}.p32-panel-val{font-family:var(--font-mono);color:var(--text-primary);text-align:right;word-break:break-all;font-size:12px}.p32-panel-val--muted{color:var(--text-muted)}.p32-panel-val--ok{color:var(--accent-green)}.p32-panel-val--warn{color:var(--accent-amber)}.p32-panel-val--err{color:var(--accent-red)}.p32-banner{align-items:center;gap:var(--spacing-md);border-radius:var(--radius-sm);margin-bottom:var(--spacing-md);background:#f59e0b14;border:1px solid #f59e0b4d;padding:12px 16px;font-size:13px;animation:.3s fadeIn;display:flex}.p32-banner-icon{color:var(--accent-amber);flex-shrink:0}.p32-banner-text{color:var(--text-primary);flex:1}.p32-banner-text strong{color:var(--accent-amber);font-weight:600}.p32-banner-keys{font-family:var(--font-mono);color:var(--text-secondary);margin-top:4px;font-size:11px}.p32-env-table{flex-direction:column;gap:0;display:flex}.p32-env-row{gap:var(--spacing-md);border-bottom:1px solid #9646ff0f;grid-template-columns:1fr auto auto auto;align-items:center;padding:10px 0;display:grid}.p32-env-row:last-child{border-bottom:none}.p32-env-key{font-family:var(--font-mono);color:var(--text-primary);word-break:break-all;font-size:12px}.p32-env-key--missing{color:var(--accent-red)}.p32-env-pill{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-full);white-space:nowrap;padding:3px 8px;font-size:10px;font-weight:500}.p32-env-pill--present{color:var(--accent-green);background:#10b9811f;border:1px solid #10b9814d}.p32-env-pill--missing{color:var(--accent-red);background:#ef44441f;border:1px solid #ef44444d}.p32-env-pill--required{color:var(--accent-violet);background:#7c3aed1f;border:1px solid #7c3aed4d}.p32-env-pill--used{color:var(--accent-cyan);background:#06b6d41f;border:1px solid #06b6d44d}.p32-env-pill--unused{color:var(--text-muted);background:#5e4d721f;border:1px solid #5e4d724d}.p32-env-len{font-family:var(--font-mono);color:var(--text-muted);font-size:11px}.p32-env-toolbar{justify-content:space-between;align-items:center;gap:var(--spacing-md);display:flex}.p32-diag-buttons{gap:var(--spacing-sm);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));display:grid}.p32-diag-output{border-radius:var(--radius-sm);padding:var(--spacing-md);font-family:var(--font-mono);color:var(--accent-green);white-space:pre-wrap;word-break:break-word;max-height:400px;margin-top:var(--spacing-md);background:#0006;border:1px solid #9646ff26;font-size:11px;overflow-y:auto}.p32-diag-meta{color:var(--text-muted);gap:var(--spacing-md);margin-top:8px;font-size:11px;display:flex}.p32-health-row{border-bottom:1px solid #9646ff0f;justify-content:space-between;align-items:center;padding:10px 0;display:flex}.p32-health-status{font-family:var(--font-mono);font-size:14px;font-weight:600}.p32-health-status--2xx{color:var(--accent-green)}.p32-health-status--3xx{color:var(--accent-cyan)}.p32-health-status--4xx{color:var(--accent-amber)}.p32-health-status--5xx,.p32-health-status--err{color:var(--accent-red)}.p32-health-body{border-radius:var(--radius-sm);padding:var(--spacing-sm);font-family:var(--font-mono);color:var(--text-secondary);white-space:pre-wrap;word-break:break-word;background:#0000004d;border:1px solid #9646ff1a;max-height:200px;font-size:11px;overflow-y:auto}.p32-health-input{gap:var(--spacing-sm);margin-top:var(--spacing-sm);align-items:center;display:flex}.p32-health-input input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-mono);flex:1;padding:8px 12px;font-size:12px}.p32-health-input input:focus{border-color:var(--accent-cyan);outline:none}.p32-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;padding:var(--spacing-lg);background:#090010d9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.p32-modal{background:var(--bg-card-solid);border-radius:var(--radius-lg);border:1px solid #9646ff33;flex-direction:column;width:100%;max-width:600px;max-height:80vh;display:flex}.p32-modal-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.p32-modal-title{color:var(--text-primary);font-size:16px;font-weight:600}.p32-modal-body{padding:var(--spacing-lg);flex:1;overflow-y:auto}.p32-modal-footer{justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border);display:flex}.p32-modal-textarea{width:100%;min-height:200px;padding:var(--spacing-md);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-mono);resize:vertical;font-size:12px}.p32-diff-section{margin-bottom:var(--spacing-md)}.p32-diff-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:8px;font-size:11px}.p32-diff-list{flex-direction:column;gap:4px;display:flex}.p32-diff-key{font-family:var(--font-mono);border-radius:var(--radius-xs);align-items:center;gap:8px;padding:4px 8px;font-size:12px;display:flex}.p32-diff-key--added{color:var(--accent-green);background:#10b98114}.p32-diff-key--removed{color:var(--accent-red);background:#ef444414}.p32-diff-key--changed{color:var(--accent-amber);background:#f59e0b14}.p32-diff-symbol{font-weight:700}.p32-diff-value{font-family:var(--font-mono);color:var(--text-primary);border-radius:var(--radius-xs);background:#0003;padding:4px 8px;font-size:12px}.p32-stage-chip{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-full);white-space:nowrap;border:1px solid;padding:2px 8px;font-size:10px;font-weight:500}.p32-stage-chip--clone{color:var(--accent-cyan);background:#06b6d414;border-color:#06b6d44d}.p32-stage-chip--install{color:var(--accent-violet);background:#7c3aed14;border-color:#7c3aed4d}.p32-stage-chip--build{color:var(--accent-amber);background:#f59e0b14;border-color:#f59e0b4d}.p32-stage-chip--start{color:var(--accent-green);background:#10b98114;border-color:#10b9814d}.p32-stage-chip--runtime{color:var(--text-secondary);background:#a48cc40d;border-color:#a48cc44d}.p32-stage-chip--health{color:var(--accent-red);background:#ef444414;border-color:#ef44444d}.p32-stage-chip--unknown{color:var(--text-muted);background:#5e4d720d;border-color:#5e4d724d}.p32-stage-filter{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.p32-stage-filter-btn{font-family:var(--font-mono);text-transform:uppercase;border-radius:var(--radius-full);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:3px 10px;font-size:10px;font-weight:500}.p32-stage-filter-btn:hover{border-color:var(--accent-cyan);color:var(--accent-cyan)}.p32-stage-filter-btn.active{background:var(--accent-cyan);color:var(--bg-primary);border-color:var(--accent-cyan)}.p32-empty{text-align:center;padding:var(--spacing-lg);color:var(--text-muted);font-size:13px}.admin-panel{max-width:1400px;padding:var(--spacing-xl);margin:0 auto;animation:.3s fadeIn}.admin-header{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);flex-wrap:wrap;display:flex}.admin-title{color:var(--text-primary);letter-spacing:-.01em;margin:0 0 6px;font-size:28px;font-weight:700}.admin-subtitle{color:var(--text-muted);margin:0;font-size:14px}.admin-stats{margin-bottom:var(--spacing-2xl);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;display:grid}.admin-stat-card{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);padding:20px var(--spacing-lg);text-align:center;transition:transform var(--transition-fast)}.admin-stat-card:hover{transform:translateY(-2px)}.admin-stat-card .stat-value{font-family:var(--font-mono);background:var(--gradient-brand-text);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:36px;font-weight:700;line-height:1}.admin-stat-card .stat-label{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:10px}.admin-section{margin-bottom:var(--spacing-2xl)}.admin-section-title{color:var(--text-primary);margin:0 0 var(--spacing-lg);letter-spacing:-.01em;font-size:18px;font-weight:700}.admin-table-wrap{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);overflow:hidden}.admin-table{border-collapse:collapse;width:100%}.admin-table th{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;text-align:left;border-bottom:1px solid var(--border);background:#1200124d;padding:14px 20px;font-size:10px;font-weight:600}.admin-table td{color:var(--text-secondary);border-bottom:1px solid #b464ff0f;padding:14px 20px;font-size:14px}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:#ffffff05}.role-badge{font-family:var(--font-mono);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.06em;padding:3px 10px;font-size:10px;font-weight:700}.role-badge-admin{color:var(--accent-violet);background:#7c3aed26;border:1px solid #7c3aed4d}.role-badge-user{color:var(--text-muted);border:1px solid var(--border);background:#6b5a7a1f}.mono{font-family:var(--font-mono);font-size:13px}.text-muted-val{color:var(--text-muted)}.admin-actions{flex-wrap:wrap;gap:8px;display:flex}.admin-error{border-radius:var(--radius-lg);padding:var(--spacing-xl);text-align:center;color:var(--accent-red);background:#ef44440d;border:1px solid #ef444433}.admin-loading{text-align:center;padding:var(--spacing-2xl);color:var(--text-muted);font-family:var(--font-mono);font-size:13px}@media (width<=768px){.admin-panel{padding:var(--spacing-md)}.admin-table-wrap{overflow-x:auto}}.notif-bell-wrap{position:relative}.notif-bell-btn{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;padding:6px;transition:color .15s,background .15s;display:flex;position:relative}.notif-bell-btn:hover{color:var(--text-primary);background:#ffffff0f}.notif-badge{background:var(--accent-red);color:#fff;min-width:16px;height:16px;font-size:9px;font-family:var(--font-mono);border-radius:999px;justify-content:center;align-items:center;padding:0 4px;font-weight:700;line-height:1;display:flex;position:absolute;top:1px;right:1px}.notif-dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);z-index:1000;width:320px;position:fixed;bottom:64px;left:252px;overflow:hidden;box-shadow:0 8px 32px #00000080}.notif-dropdown-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.notif-dropdown-title{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:11px;font-weight:600}.notif-clear-btn{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;gap:4px;padding:3px 6px;font-size:11px;transition:color .15s;display:flex}.notif-clear-btn:hover{color:var(--text-primary)}.notif-empty{text-align:center;color:var(--text-muted);padding:24px 14px;font-size:13px}.notif-list{max-height:320px;overflow-y:auto}.notif-item{border-bottom:1px solid var(--border);cursor:pointer;align-items:flex-start;gap:10px;padding:12px 14px;transition:background .15s;display:flex}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:#ffffff08}.notif-item.notif-read{opacity:.55;cursor:default}.notif-type-icon{flex-shrink:0;margin-top:1px;font-size:14px}.notif-item-body{flex:1;min-width:0}.notif-message{color:var(--text-primary);margin:0 0 4px;font-size:13px;line-height:1.4}.notif-time{font-family:var(--font-mono);color:var(--text-muted);font-size:10px}.notif-unread-dot{background:var(--accent-blue);border-radius:50%;flex-shrink:0;width:7px;height:7px;margin-top:5px}.sidebar{-webkit-backdrop-filter:blur(20px);z-index:100;background:#0e0416eb;border-right:1px solid #9646ff1f;flex-direction:column;width:240px;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{cursor:pointer;-webkit-user-select:none;user-select:none;border-bottom:1px solid #9646ff1a;align-items:center;gap:10px;padding:22px 18px;display:flex}.logo-icon-wrap{flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.logo-text{background:var(--gradient-brand-text);-webkit-text-fill-color:transparent;letter-spacing:-.01em;-webkit-background-clip:text;background-clip:text;font-size:17px;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:14px 10px;display:flex;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:0 0}.sidebar-nav::-webkit-scrollbar-thumb{background:#7c3aed33;border-radius:2px}.sidebar-nav-item{border-radius:var(--radius-sm);color:var(--text-muted);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:9px 12px;font-size:14px;font-weight:500;text-decoration:none;display:flex;position:relative}.sidebar-nav-item:hover{color:var(--text-secondary);background:#ffffff0d}.sidebar-nav-item.active{color:var(--accent-cyan);background:#06b6d414}.sidebar-nav-item.active:before{content:"";background:var(--gradient-brand);border-radius:0 2px 2px 0;width:3px;position:absolute;top:0;bottom:0;left:0}.nav-icon{width:20px;color:inherit;flex-shrink:0;justify-content:center;align-items:center;display:flex}.nav-label{flex:1}.nav-badge{font-family:var(--font-mono);background:var(--gradient-brand);color:#fff;border-radius:var(--radius-full);letter-spacing:.04em;text-transform:uppercase;padding:2px 6px;font-size:9px;font-weight:700}.nav-arrow{color:var(--text-muted);transition:transform var(--transition-fast), color var(--transition-fast);flex-shrink:0}@keyframes arrowPulse{0%{opacity:1;transform:scale(1)}40%{opacity:.65;transform:scale(1.45)}70%{opacity:1;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.nav-arrow.sub-open{color:var(--accent-cyan);animation:1.4s ease-in-out infinite arrowPulse}.sidebar-nav-external{text-decoration:none}.sidebar-user{border-top:1px solid #9646ff1a;align-items:center;gap:10px;padding:14px 10px;display:flex}.sidebar-user-info{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.user-avatar{background:var(--gradient-brand);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;font-weight:700;display:flex}.user-details{flex:1;min-width:0}.user-email{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:500;overflow:hidden}.user-role{font-family:var(--font-mono);color:var(--accent-violet);text-transform:uppercase;letter-spacing:.06em;margin-top:2px;font-size:10px}.sidebar-logout{border:1px solid var(--border);border-radius:var(--radius-sm);width:30px;height:30px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-logout:hover{color:var(--accent-red);background:#ef44441a;border-color:#ef44444d}.sidebar-mobile-toggle{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-sm);width:40px;height:40px;color:var(--text-primary);cursor:pointer;z-index:101;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);justify-content:center;align-items:center;display:none;position:fixed;top:14px;right:14px}.sidebar-mobile-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:99;background:#090010bf;display:none;position:fixed;inset:0}@media (width<=768px){.sidebar{animation:none;transform:translate(-100%)}.sidebar.sidebar-mobile-open{animation:.2s ease-out slideInLeft;transform:translate(0)}.sidebar-mobile-toggle{display:flex}.sidebar-mobile-overlay{display:block}}.sub-sidebar{-webkit-backdrop-filter:blur(28px);z-index:99;background:#0e0416f7;border:1px solid #9646ff1f;border-radius:0;flex-direction:column;width:196px;display:flex;position:fixed;left:248px;overflow:hidden;box-shadow:0 0 0 1px #06b6d40f,0 20px 40px #0000008c,0 0 80px #06b6d40d}.sub-sidebar-header{background:#06b6d40a;border-bottom:1px solid #06b6d41a;flex-shrink:0;padding:16px 16px 12px}.sub-sidebar-title{font-family:var(--font-mono);color:var(--accent-cyan);text-transform:uppercase;letter-spacing:.12em;font-size:10px;font-weight:700}.sub-sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:8px;display:flex;overflow-y:auto}.sub-sidebar-item{border-radius:var(--radius-sm);color:#94b4bea6;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);text-align:left;background:0 0;border:none;align-items:center;width:100%;padding:9px 12px;font-size:13px;font-weight:500;display:flex;position:relative}.sub-sidebar-item:hover{color:var(--text-primary);background:#06b6d414}.sub-sidebar-item.active{color:var(--accent-cyan);background:#06b6d41f}.sub-active-bar{background:var(--gradient-brand);border-radius:0 2px 2px 0;width:2px;position:absolute;top:0;bottom:0;left:0}.sub-sidebar-connector{z-index:98;transform-origin:0;background:#9646ff4d;width:8px;height:2px;position:fixed;left:240px}.sub-sidebar-connector:before,.sub-sidebar-connector:after{content:"";filter:drop-shadow(0 0 3px #00f0ffe6);border:3px solid #0000;border-left:5px solid #00f0ff;border-right-width:0;width:0;height:0;position:absolute;top:50%;left:0}.sub-sidebar-connector:before{animation:1.1s linear infinite arrowSlide}.sub-sidebar-connector:after{animation:1.1s linear .55s infinite arrowSlide}@keyframes arrowSlide{0%{opacity:0;transform:translateY(-50%)translate(-5px)}15%{opacity:1}85%{opacity:.9}to{opacity:0;transform:translateY(-50%)translate(13px)}}@media (width<=768px){.sub-sidebar,.sub-sidebar-connector{display:none}}.sub-sidebar-inline{border-left:2px solid #06b6d433;flex-direction:column;gap:1px;margin:2px 0 2px 32px;padding-left:12px;display:none}.sub-sidebar-inline-item{border-radius:var(--radius-sm);color:#94b4bea6;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);text-align:left;background:0 0;border:none;align-items:center;width:100%;padding:8px 10px;font-size:13px;font-weight:500;display:flex}.sub-sidebar-inline-item:hover{color:var(--text-primary);background:#06b6d414}.sub-sidebar-inline-item.active{color:var(--accent-cyan);background:#06b6d41f}@media (width<=768px){.sub-sidebar-inline{display:flex}}.main-layout{background:var(--bg-primary);min-height:100vh;display:flex}@keyframes dotFlow{0%{background-position:0 0}to{background-position:44px 44px}}.main-content{flex:1;min-height:100vh;margin-left:240px;transition:margin-left .18s;position:relative}.main-content:before{content:"";pointer-events:none;z-index:0;background-image:radial-gradient(#3b82f626 1px,#0000 1px);background-size:22px 22px;animation:6s linear infinite dotFlow;position:fixed;inset:0}@media (width<=768px){.main-content{margin-left:0}}.usage-page{max-width:1400px;padding:var(--spacing-xl);margin:0 auto;animation:.3s fadeIn}.page-header{margin-bottom:var(--spacing-xl)}.page-title{color:var(--text-primary);letter-spacing:-.01em;margin:0 0 6px;font-size:28px;font-weight:700}.page-subtitle{color:var(--text-muted);margin:0;font-size:14px}.usage-stats-grid{margin-bottom:var(--spacing-2xl);grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;display:grid}.usage-stat-card{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);transition:transform var(--transition-fast), box-shadow var(--transition-fast);align-items:flex-start;gap:16px;padding:22px;display:flex}.usage-stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 32px #7c3aed26}.stat-icon{flex-shrink:0;font-size:28px;line-height:1}.stat-content{flex:1}.stat-label{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px;font-size:10px;font-weight:600}.stat-value{font-family:var(--font-mono);color:var(--text-primary);margin-bottom:4px;font-size:32px;font-weight:700;line-height:1}.stat-trend{color:var(--text-muted);font-size:12px}.usage-section{margin-bottom:var(--spacing-2xl)}.section-title{color:var(--text-primary);margin:0 0 var(--spacing-lg);letter-spacing:-.01em;font-size:18px;font-weight:700}.usage-coming-soon{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);text-align:center;padding:64px 32px}.coming-soon-icon{margin-bottom:16px;font-size:56px;line-height:1}.usage-coming-soon h3{color:var(--text-primary);margin:0 0 8px;font-size:20px;font-weight:700}.usage-coming-soon p{color:var(--text-muted);margin:0;font-size:14px}@media (width<=768px){.usage-page{padding:var(--spacing-md)}.usage-stats-grid{grid-template-columns:1fr}.stat-value{font-size:26px}}.templates-container{max-width:1400px;padding:var(--spacing-xl);margin:0 auto;animation:.3s fadeIn}.templates-header{margin-bottom:var(--spacing-xl);flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:20px;display:flex}.templates-header h1{color:var(--text-primary);letter-spacing:-.01em;margin:0 0 6px;font-size:28px;font-weight:700}.templates-subtitle{color:var(--text-muted);margin:0;font-size:14px}.submit-template-btn{color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:9px 18px;font-size:14px;font-weight:500}.submit-template-btn:hover{color:var(--text-primary);border-color:var(--border-hover);background:var(--bg-elevated)}.templates-alert{border-radius:var(--radius-sm);margin-bottom:20px;padding:11px 14px;font-size:14px}.alert-success{color:var(--accent-green);background:#10b9811a;border:1px solid #10b9814d}.alert-error{color:var(--accent-red);background:#ef44441a;border:1px solid #ef44444d}.templates-controls{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);margin-bottom:var(--spacing-xl);flex-direction:column;gap:14px;padding:20px;display:flex}.template-search{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);width:100%;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:10px 14px;font-size:14px}.template-search:focus{border-color:var(--accent-cyan);outline:none;box-shadow:0 0 0 3px #06b6d426}.template-search::placeholder{color:var(--text-muted)}.category-filters{flex-wrap:wrap;gap:6px;display:flex}.category-filter{border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:6px 14px;font-size:13px;font-weight:500}.category-filter:hover{color:var(--text-secondary);border-color:var(--border-hover);background:#ffffff0a}.category-filter.active{background:var(--gradient-brand);color:#fff;border-color:#0000}.templates-grid{margin-bottom:var(--spacing-2xl);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;display:grid}.template-card{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);transition:transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);padding:22px;position:relative}.template-card:hover{box-shadow:0 12px 40px #7c3aed33, var(--glass-shadow);border-color:#06b6d44d;transform:translateY(-3px)}.template-icon{margin-bottom:14px;font-size:40px;line-height:1}.template-badge{border-radius:var(--radius-full);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;padding:3px 10px;font-size:10px;font-weight:600;position:absolute;top:16px;right:16px}.badge-popular{color:var(--accent-cyan);background:#06b6d41f;border:1px solid #06b6d44d}.badge-full-stack{color:var(--accent-violet);background:#7c3aed1f;border:1px solid #7c3aed4d}.badge-backend{color:var(--accent-green);background:#10b9811f;border:1px solid #10b9814d}.badge-database{color:var(--accent-amber);background:#f59e0b1f;border:1px solid #f59e0b4d}.template-name{color:var(--text-primary);margin:0 0 10px;font-size:18px;font-weight:700}.template-description{color:var(--text-secondary);margin-bottom:14px;font-size:14px;line-height:1.6}.template-tags{flex-wrap:wrap;gap:6px;margin-bottom:14px;display:flex}.template-tag{font-family:var(--font-mono);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-muted);background:#12001280;padding:2px 8px;font-size:10px}.template-meta{border-top:1px solid var(--border);border-bottom:1px solid var(--border);gap:14px;margin-bottom:14px;padding:10px 0;display:flex}.meta-item{color:var(--text-muted);align-items:center;gap:5px;font-size:12px;display:flex}.meta-icon{font-size:13px}.deploy-button{background:var(--gradient-brand);color:#fff;border-radius:var(--radius-sm);cursor:pointer;width:100%;transition:all var(--transition-fast);border:none;justify-content:center;align-items:center;gap:7px;padding:10px 20px;font-size:14px;font-weight:600;display:flex}.deploy-button:hover:not(:disabled){background:var(--gradient-brand-hover);box-shadow:var(--glow-cyan);transform:translateY(-1px)}.deploy-button:disabled{opacity:.5;cursor:not-allowed}.button-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.6s linear infinite spin}.templates-empty{text-align:center;color:var(--text-muted);padding:80px 20px}.empty-icon{margin-bottom:16px;font-size:56px}.templates-empty h3{color:var(--text-secondary);margin-bottom:8px;font-size:18px}.templates-empty p{font-size:14px}.templates-loading{text-align:center;color:var(--text-muted);align-items:center;gap:var(--spacing-md);flex-direction:column;padding:80px 20px;display:flex}.templates-info{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);padding:var(--spacing-xl);margin-top:var(--spacing-2xl)}.templates-info h2{color:var(--text-primary);margin:0 0 var(--spacing-xl);text-align:center;font-size:22px;font-weight:700}.info-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;display:grid}.info-card{text-align:center;padding:16px}.info-icon{margin-bottom:10px;font-size:32px}.info-card h3{color:var(--text-primary);margin:0 0 6px;font-size:15px;font-weight:700}.info-card p{color:var(--text-secondary);margin:0;font-size:13px;line-height:1.6}@media (width<=768px){.templates-header{flex-direction:column;align-items:flex-start}.templates-grid,.info-grid{grid-template-columns:1fr}}.settings-container{max-width:900px;padding:var(--spacing-xl);margin:0 auto;animation:.3s fadeIn}.settings-header{margin-bottom:var(--spacing-xl)}.settings-header h1{color:var(--text-primary);letter-spacing:-.01em;margin:0 0 6px;font-size:28px;font-weight:700}.settings-subtitle{color:var(--text-muted);margin:0;font-size:14px}.settings-content{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);padding:var(--spacing-xl)}.settings-section{margin-bottom:var(--spacing-xl)}.settings-section:last-child{margin-bottom:0}.settings-section-title{color:var(--text-primary);margin:0 0 var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border);font-size:16px;font-weight:700}.form-group{margin-bottom:var(--spacing-md);flex-direction:column;gap:6px;display:flex}.form-label{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:11px;font-weight:600}.form-input,.form-select,.form-textarea{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;font-family:var(--font-sans);width:100%;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:10px 14px}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent-cyan);outline:none;box-shadow:0 0 0 3px #06b6d426}.form-select{appearance:none;cursor:pointer}.button-primary{background:var(--gradient-brand);color:#fff;border-radius:var(--radius-sm);font-size:14px;font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);border:none;align-items:center;gap:6px;padding:9px 18px;display:inline-flex}.button-primary:hover{background:var(--gradient-brand-hover);box-shadow:var(--glow-cyan);transform:translateY(-1px)}.button-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.settings-button{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:14px;font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);background:0 0;align-items:center;gap:6px;padding:8px 16px;display:inline-flex}.settings-button:hover{border-color:var(--border-hover);color:var(--text-primary);background:var(--bg-elevated)}.settings-button:disabled{opacity:.5;cursor:not-allowed}.button-danger{border-radius:var(--radius-sm);color:var(--accent-red);font-size:14px;font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:1px solid #ef44444d;padding:8px 16px}.button-danger:hover{box-shadow:var(--glow-red);background:#ef44441a}@media (width<=768px){.settings-container{padding:var(--spacing-md)}}.link-db-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1100;background:#120012d1;justify-content:center;align-items:center;padding:16px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.link-db-modal{border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:#160622f7;border:1px solid #b464ff33;width:100%;max-width:460px;animation:.2s slideUp;box-shadow:0 24px 64px #0009,0 0 0 1px #06b6d414}.link-db-header{border-radius:var(--radius-lg) var(--radius-lg) 0 0;background:#12001266;border-bottom:1px solid #b464ff1f;justify-content:space-between;align-items:center;padding:18px 24px 14px;display:flex}.link-db-title{font-family:var(--font-mono);color:var(--text-primary);margin:0;font-size:15px;font-weight:600}.link-db-close{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-xs);width:30px;height:30px;transition:all var(--transition-fast);background:0 0;border:1px solid #b464ff26;justify-content:center;align-items:center;padding:0;font-size:16px;display:flex}.link-db-close:hover{color:var(--accent-red);background:#ef44441a;border-color:#ef44444d}.link-db-form{flex-direction:column;gap:18px;padding:20px 24px 24px;display:flex}.link-db-desc{font-family:var(--font-sans);color:var(--text-muted);margin:0;font-size:13px;line-height:1.55}.link-db-desc strong{color:var(--text-secondary);font-weight:600}.link-db-field{flex-direction:column;gap:8px;display:flex}.link-db-label{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:10px;font-weight:600}.link-db-select,.link-db-input{background:var(--bg-input);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-mono);width:100%;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);box-sizing:border-box;-webkit-appearance:none;border:1px solid #b464ff26;outline:none;padding:10px 12px;font-size:13px}.link-db-select:focus,.link-db-input:focus{border-color:var(--accent-cyan);box-shadow:0 0 0 3px #06b6d426}.link-db-input::placeholder{color:var(--text-muted)}.link-db-select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b5a7a' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:32px}.link-db-select option{color:var(--text-primary);background:#1a0628}.link-db-hint{font-family:var(--font-sans);color:var(--text-muted);margin:0;font-size:12px;line-height:1.5}.link-db-hint code{font-family:var(--font-mono);color:var(--accent-cyan);background:#06b6d41a;border-radius:3px;padding:1px 5px}.link-db-error{font-family:var(--font-sans);color:var(--accent-red);border-radius:var(--radius-sm);background:#ef444414;border:1px solid #ef44444d;margin:0;padding:10px 14px;font-size:13px}.link-db-footer{justify-content:flex-end;gap:10px;display:flex}.link-btn{border-radius:var(--radius-sm);font-family:var(--font-mono);cursor:pointer;transition:all var(--transition-fast);border:none;align-items:center;padding:9px 18px;font-size:13px;font-weight:500;display:inline-flex}.link-btn-primary{background:var(--gradient-brand);color:#fff}.link-btn-primary:hover:not(:disabled){background:var(--gradient-brand-hover);box-shadow:var(--glow-cyan)}.link-btn-secondary{color:var(--text-secondary);background:0 0;border:1px solid #b464ff26}.link-btn-secondary:hover:not(:disabled){color:var(--text-primary);background:#ffffff08;border-color:#06b6d466}.link-btn:disabled{opacity:.5;cursor:not-allowed}.db-card{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);overflow:hidden}.db-card:hover{border-color:#b464ff40}.db-card-expanded{border-color:#06b6d459;box-shadow:0 0 24px #06b6d41a}.db-card-header{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.db-card-header:hover{background:#ffffff05}.db-card-header-left{align-items:center;gap:12px;display:flex}.db-type-icon{border-radius:var(--radius-md);background:#06b6d41f;border:1px solid #06b6d440;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:18px;line-height:1;display:flex}.db-card-info{flex-direction:column;gap:4px;display:flex}.db-card-name{font-family:var(--font-mono);color:var(--text-primary);font-size:15px;font-weight:600}.db-card-meta{align-items:center;gap:8px;display:flex}.db-type-badge{font-family:var(--font-mono);color:var(--accent-cyan);border-radius:var(--radius-full);background:#06b6d41a;border:1px solid #06b6d440;padding:2px 8px;font-size:10px;font-weight:600}.db-port{font-family:var(--font-mono);color:var(--text-muted);font-size:12px}.db-card-header-right{align-items:center;gap:12px;display:flex}.db-status-dot{font-family:var(--font-mono);color:var(--dot-color,var(--text-muted));align-items:center;gap:6px;font-size:12px;display:inline-flex}.dot-indicator{background:currentColor;border-radius:50%;flex-shrink:0;width:8px;height:8px}.dot-pulse{animation:2s ease-in-out infinite dotPulse}@keyframes dotPulse{0%,to{opacity:1}50%{opacity:.3}}.db-card-chevron{color:var(--text-muted);align-items:center;display:flex}.db-card-body{border-top:1px solid var(--border);padding:0 20px 20px}.db-loading-text{color:var(--text-muted);padding:16px 0;font-size:13px}.db-section{margin-top:16px}.db-section-label{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;font-size:10px;font-weight:600}.db-section-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.db-section-header .db-section-label{margin-bottom:0}.db-connection-row{border:1px solid var(--border);border-radius:var(--radius-sm);background:#12001299;align-items:stretch;gap:0;display:flex;overflow:hidden}.db-connection-string{font-family:var(--font-mono);color:var(--accent-green);white-space:nowrap;background:0 0;border:none;flex:1;padding:10px 12px;font-size:11px;overflow-x:auto}.db-copy-btn{border:none;border-left:1px solid var(--border);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:#1e0a28cc;flex-shrink:0;align-items:center;padding:0 12px;display:flex}.db-copy-btn:hover{color:var(--accent-cyan);background:#06b6d426}.db-credentials-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;display:grid}.db-cred-item{border:1px solid var(--border);border-radius:var(--radius-sm);background:#12001280;padding:10px 12px}.db-cred-label{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px;font-size:9px;font-weight:600;display:block}.db-cred-value{font-family:var(--font-mono);color:var(--text-secondary);font-size:12px}.db-cred-item-full{grid-column:1/-1}.db-cred-password-row{align-items:center;gap:8px;display:flex}.db-cred-pw{text-overflow:ellipsis;white-space:nowrap;letter-spacing:.05em;flex:1;overflow:hidden}.db-cred-action-btn{font-family:var(--font-mono);color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius-xs);cursor:pointer;transition:all var(--transition-fast);background:0 0;flex-shrink:0;align-items:center;gap:4px;padding:3px 8px;font-size:11px;display:flex}.db-cred-action-btn:hover{border-color:var(--accent-cyan);color:var(--accent-cyan)}.db-hint-text{color:var(--text-muted);margin:0;font-size:13px;line-height:1.5}.db-links-list{flex-direction:column;gap:6px;display:flex}.db-link-item{border:1px solid var(--border);border-radius:var(--radius-sm);background:#12001266;align-items:center;gap:10px;padding:8px 12px;display:flex}.db-link-project{color:var(--text-primary);flex:1;font-size:13px}.db-link-var{font-family:var(--font-mono);color:var(--accent-cyan);border-radius:var(--radius-xs);background:#06b6d414;padding:2px 6px;font-size:11px}.db-unlink-btn{font-family:var(--font-mono);color:var(--accent-red);border-radius:var(--radius-xs);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:1px solid #ef44444d;padding:2px 8px;font-size:11px}.db-unlink-btn:hover{background:#ef44441a}.db-small-btn{font-family:var(--font-mono);color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius-xs);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:3px 10px;font-size:11px}.db-small-btn:hover{border-color:var(--accent-cyan);color:var(--accent-cyan)}.db-backups-list{flex-direction:column;gap:4px;display:flex}.db-backup-item{border:1px solid var(--border);border-radius:var(--radius-xs);background:#12001266;grid-template-columns:1fr auto auto;align-items:center;gap:12px;padding:6px 10px;display:grid}.db-backup-filename{font-family:var(--font-mono);color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.db-backup-size{font-family:var(--font-mono);color:var(--text-muted);white-space:nowrap;font-size:11px}.db-backup-date{color:var(--text-muted);white-space:nowrap;font-size:11px}.db-card-actions{border-top:1px solid var(--border);flex-wrap:wrap;gap:8px;margin-top:20px;padding-top:16px;display:flex}.db-card-actions .btn{padding:6px 12px;font-size:12px}.create-db-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;background:#120012d1;justify-content:center;align-items:center;padding:16px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.create-db-modal{border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:#160622f7;border:1px solid #b464ff33;width:100%;max-width:560px;max-height:90vh;animation:.2s slideUp;overflow-y:auto;box-shadow:0 24px 64px #0009,0 0 0 1px #06b6d414}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.create-db-header{border-radius:var(--radius-lg) var(--radius-lg) 0 0;background:#12001266;border-bottom:1px solid #b464ff1f;justify-content:space-between;align-items:center;padding:18px 24px 14px;display:flex}.create-db-title{font-family:var(--font-mono);color:var(--text-primary);margin:0;font-size:15px;font-weight:600}.create-db-close{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-xs);width:30px;height:30px;transition:all var(--transition-fast);background:0 0;border:1px solid #b464ff26;justify-content:center;align-items:center;padding:0;font-size:16px;display:flex}.create-db-close:hover{color:var(--accent-red);background:#ef44441a;border-color:#ef44444d}.create-db-form{flex-direction:column;gap:20px;padding:20px 24px 24px;display:flex}.create-db-field{flex-direction:column;gap:8px;display:flex}.create-db-label{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:10px;font-weight:600}.db-type-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.db-type-option{border-radius:var(--radius-sm);cursor:pointer;text-align:left;transition:all var(--transition-fast);background:#12001280;border:1px solid #b464ff26;flex-direction:column;align-items:flex-start;gap:3px;padding:12px 14px;display:flex}.db-type-option:hover{background:#06b6d40d;border-color:#06b6d466}.db-type-selected{border-color:var(--accent-cyan);background:#06b6d414;box-shadow:0 0 0 1px #06b6d44d}.db-type-option-icon{margin-bottom:2px;font-size:20px;line-height:1}.db-type-option-label{font-family:var(--font-mono);color:var(--text-primary);font-size:13px;font-weight:600}.db-type-option-version{font-family:var(--font-mono);color:var(--text-muted);font-size:10px}.db-type-option-desc{font-family:var(--font-sans);color:var(--text-secondary);margin-top:2px;font-size:11px;line-height:1.4}.create-db-input,.create-db-select{background:var(--bg-input);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-mono);width:100%;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);box-sizing:border-box;-webkit-appearance:none;border:1px solid #b464ff26;outline:none;padding:10px 12px;font-size:13px}.create-db-input:focus,.create-db-select:focus{border-color:var(--accent-cyan);box-shadow:0 0 0 3px #06b6d426}.create-db-input::placeholder{color:var(--text-muted)}.create-db-select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b5a7a' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:32px}.create-db-select option{color:var(--text-primary);background:#1a0628}.create-db-hint{font-family:var(--font-sans);color:var(--text-muted);margin:0;font-size:12px}.create-db-error{font-family:var(--font-sans);color:var(--accent-red);border-radius:var(--radius-sm);background:#ef444414;border:1px solid #ef44444d;margin:0;padding:10px 14px;font-size:13px}.create-db-footer{justify-content:flex-end;gap:10px;padding-top:4px;display:flex}.create-db-modal .btn{border-radius:var(--radius-sm);font-family:var(--font-mono);cursor:pointer;transition:all var(--transition-fast);border:none;align-items:center;padding:9px 18px;font-size:13px;font-weight:500;display:inline-flex}.create-db-modal .btn-primary{background:var(--gradient-brand);color:#fff}.create-db-modal .btn-primary:hover:not(:disabled){background:var(--gradient-brand-hover);box-shadow:var(--glow-cyan)}.create-db-modal .btn-secondary,.create-db-modal .btn-ghost{color:var(--text-secondary);background:0 0;border:1px solid #b464ff26}.create-db-modal .btn-secondary:hover:not(:disabled),.create-db-modal .btn-ghost:hover:not(:disabled){color:var(--text-primary);background:#ffffff08;border-color:#06b6d466}.create-db-modal .btn:disabled{opacity:.5;cursor:not-allowed}.databases-page{max-width:1200px;padding:var(--spacing-xl);margin:0 auto;animation:.3s fadeIn}.databases-header{justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);flex-wrap:wrap;display:flex}.databases-header-left{flex:1}.databases-title{color:var(--text-primary);letter-spacing:-.01em;margin:0 0 6px;font-size:28px;font-weight:700}.databases-subtitle{color:var(--text-muted);margin:0;font-size:14px}.databases-grid{grid-template-columns:repeat(auto-fill,minmax(500px,1fr));gap:16px;display:grid}.databases-loading{text-align:center;padding:var(--spacing-2xl);color:var(--text-muted);align-items:center;gap:var(--spacing-md);flex-direction:column;display:flex}.loading-spinner{border:2px solid var(--border);border-top-color:var(--accent-cyan);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}.databases-error{border-radius:var(--radius-lg);padding:var(--spacing-xl);text-align:center;color:var(--accent-red);background:#ef44440d;border:1px solid #ef444433}.databases-error p{margin-bottom:var(--spacing-md)}.databases-empty{text-align:center;padding:80px var(--spacing-xl)}.empty-icon-wrap{border-radius:var(--radius-xl);width:72px;height:72px;margin:0 auto var(--spacing-lg);color:var(--text-muted);background:#06b6d414;border:1px solid #06b6d433;justify-content:center;align-items:center;display:flex}.empty-title{color:var(--text-primary);margin-bottom:var(--spacing-sm);font-size:20px;font-weight:700}.empty-description{color:var(--text-muted);max-width:440px;margin:0 auto var(--spacing-lg);font-size:14px;line-height:1.6}@media (width<=768px){.databases-page{padding:var(--spacing-md)}.databases-grid{grid-template-columns:1fr}}.billing-page{padding:var(--spacing-xl);max-width:900px;margin:0 auto;animation:.3s fadeIn}.billing-header{margin-bottom:var(--spacing-xl)}.billing-title{color:var(--text-primary);letter-spacing:-.01em;margin:0 0 6px;font-size:28px;font-weight:700}.billing-subtitle{color:var(--text-muted);margin:0;font-size:14px}.billing-loading,.billing-error{color:var(--text-muted);font-size:14px;font-family:var(--font-mono);padding:2rem 0}.billing-banner{border-radius:var(--radius-sm);border:1px solid;margin-bottom:20px;padding:11px 14px;font-size:14px}.billing-banner-success{color:var(--accent-green);background:#10b9811a;border-color:#10b9814d}.billing-banner-info{color:var(--accent-cyan);background:#06b6d41a;border-color:#06b6d44d}.billing-banner-warn{color:var(--accent-amber);background:#f59e0b1a;border-color:#f59e0b4d}.billing-grid{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;display:grid}@media (width<=640px){.billing-grid{grid-template-columns:1fr}}.billing-card{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);padding:22px}.billing-comparison{margin-top:0}.billing-card-header{margin-bottom:var(--spacing-md);justify-content:space-between;align-items:center;display:flex}.billing-card-title{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:10px;font-weight:600}.billing-plan-badge{font-family:var(--font-mono);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.06em;padding:3px 10px;font-size:10px;font-weight:600}.billing-plan-badge.free{color:var(--text-muted);background:#6b5a7a26;border:1px solid #6b5a7a4d}.billing-plan-badge.pro{color:var(--accent-cyan);background:#06b6d41f;border:1px solid #06b6d44d}.billing-plan-price{font-family:var(--font-mono);color:var(--text-primary);margin-bottom:6px;font-size:32px;font-weight:700;line-height:1}.billing-plan-price span{color:var(--text-muted);font-size:14px;font-weight:400}.billing-plan-renew{color:var(--text-muted);margin-bottom:12px;font-size:13px}.billing-plan-note{color:var(--text-muted);margin-bottom:var(--spacing-md);font-size:13px;line-height:1.5}.billing-upgrade-btn{background:var(--gradient-brand);color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);text-align:center;border:none;width:100%;padding:10px 18px;font-size:14px;font-weight:600;display:inline-block}.billing-upgrade-btn:hover:not(:disabled){background:var(--gradient-brand-hover);box-shadow:var(--glow-cyan);transform:translateY(-1px)}.billing-upgrade-btn:disabled{opacity:.5;cursor:not-allowed}.billing-upgrade-btn-sm{margin-top:12px;padding:8px 14px;font-size:13px}.billing-usage-list{gap:var(--spacing-md);flex-direction:column;display:flex}.billing-usage-row{flex-direction:column;gap:6px;display:flex}.billing-usage-label{color:var(--text-secondary);justify-content:space-between;font-size:13px;display:flex}.billing-usage-count{font-family:var(--font-mono);color:var(--text-primary);font-size:12px}.billing-usage-bar-track{background:#b464ff1a;border-radius:3px;height:5px;overflow:hidden}.billing-usage-bar-fill{background:var(--accent-green);border-radius:3px;height:100%;transition:width .3s}.billing-usage-bar-fill.warn{background:var(--accent-amber)}.billing-usage-bar-fill.danger{background:var(--accent-red)}.billing-usage-value{color:var(--text-primary);font-size:13px}.billing-usage-locked{color:var(--text-muted);font-style:italic}.billing-compare-grid{gap:var(--spacing-md);grid-template-columns:1fr 1fr;display:grid}@media (width<=480px){.billing-compare-grid{grid-template-columns:1fr}}.billing-compare-col{flex-direction:column;gap:8px;display:flex}.billing-compare-col-pro{border-radius:var(--radius-sm);background:#06b6d40a;border:1px solid #06b6d433;padding:12px}.billing-compare-plan-name{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:2px;font-size:10px;font-weight:700}.billing-compare-plan-price{font-family:var(--font-mono);color:var(--text-primary);margin-bottom:8px;font-size:22px;font-weight:700}.billing-compare-plan-price span{color:var(--text-muted);font-size:13px;font-weight:400}.billing-compare-row{color:var(--text-secondary);align-items:center;gap:6px;font-size:13px;display:flex}.billing-compare-row.locked{color:var(--text-muted);text-decoration:line-through}.billing-compare-icon{color:var(--accent-green);flex-shrink:0;width:14px;font-size:12px}.billing-compare-row.locked .billing-compare-icon{color:var(--text-muted)}.billing-compare-current-badge{font-family:var(--font-mono);color:var(--text-muted);text-align:center;border-radius:var(--radius-xs);border:1px solid #6b5a7a4d;margin-top:8px;padding:4px;font-size:10px}.billing-compare-current-badge.pro{color:var(--accent-cyan);border-color:#06b6d44d}.billing-plan-meta{flex-direction:column;gap:6px;margin:10px 0 14px;display:flex}.billing-plan-meta-row{justify-content:space-between;align-items:center;font-size:13px;display:flex}.billing-meta-label{color:var(--text-muted)}.billing-meta-value{font-family:var(--font-mono);color:var(--text-secondary);font-size:12px}.billing-error-inline{color:var(--accent-red);margin:10px 0;font-size:13px}.billing-empty-state{color:var(--text-muted);padding:24px 0 8px;font-size:14px}.billing-empty-sub{color:var(--text-muted);opacity:.7;margin-top:4px;font-size:12px}.billing-invoices-table{flex-direction:column;gap:0;margin-top:4px;display:flex}.billing-invoices-thead{border-bottom:1px solid var(--border);font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;grid-template-columns:1.2fr 1.4fr .8fr .8fr .4fr;gap:8px;padding:8px 0;font-size:10px;font-weight:600;display:grid}.billing-invoices-row{color:var(--text-secondary);transition:background var(--transition-fast);border-bottom:1px solid #ffffff0a;grid-template-columns:1.2fr 1.4fr .8fr .8fr .4fr;align-items:center;gap:8px;padding:11px 0;font-size:13px;display:grid}.billing-invoices-row:last-child{border-bottom:none}.billing-invoices-row:hover{background:#ffffff05}.billing-inv-date{color:var(--text-secondary)}.billing-inv-number{font-family:var(--font-mono);color:var(--text-muted);font-size:12px}.billing-inv-amount{font-family:var(--font-mono);color:var(--text-primary);font-size:13px}.billing-inv-status{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.04em;border-radius:var(--radius-full);width:fit-content;padding:2px 8px;font-size:10px;font-weight:600}.billing-inv-status.paid{color:var(--accent-green);background:#10b9811a;border:1px solid #10b98140}.billing-inv-status.open,.billing-inv-status.uncollectible{color:var(--accent-amber);background:#f59e0b1a;border:1px solid #f59e0b40}.billing-inv-status.void,.billing-inv-status.draft{color:var(--text-muted);background:#6b5a7a1a;border:1px solid #6b5a7a33}.billing-inv-link{font-family:var(--font-mono);color:var(--accent-cyan);transition:opacity var(--transition-fast);font-size:11px;text-decoration:none}.billing-inv-link:hover{opacity:.75}.billing-subscription-layout{flex-direction:column;gap:16px;display:flex}.billing-sub-meta-grid{grid-template-columns:1fr 1fr;gap:12px 24px;margin:6px 0 20px;display:grid}@media (width<=560px){.billing-sub-meta-grid{grid-template-columns:1fr}}.billing-sub-meta-item{flex-direction:column;gap:3px;display:flex}.billing-sub-meta-label{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-weight:600}.billing-sub-meta-value{color:var(--text-primary);font-size:14px}.billing-sub-meta-value.status-ok{color:var(--accent-green)}.billing-sub-meta-value.status-warn{color:var(--accent-amber)}.billing-portal-btn{color:var(--accent-cyan);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);text-align:center;background:0 0;border:1px solid #06b6d459;width:100%;margin-bottom:10px;padding:10px 18px;font-size:14px;font-weight:600;display:inline-block}.billing-portal-btn:hover:not(:disabled){background:#06b6d414;border-color:#06b6d499;box-shadow:0 0 12px #06b6d426}.billing-portal-btn:disabled{opacity:.5;cursor:not-allowed}.billing-portal-note{color:var(--text-muted);margin:0;font-size:12px;line-height:1.5}.billing-features-list{flex-direction:column;gap:10px;padding-top:4px;display:flex}.billing-feature-row{color:var(--text-secondary);align-items:center;gap:10px;font-size:13px;display:flex}.billing-feature-check{color:var(--accent-green);flex-shrink:0;width:14px;font-size:12px}@media (width<=640px){.billing-invoices-thead,.billing-invoices-row{grid-template-columns:1fr 1fr .8fr .7fr .5fr}.billing-inv-number{display:none}}.obs-page{max-width:1200px;padding:var(--spacing-xl);margin:0 auto;animation:.3s fadeIn}.obs-header{justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);flex-wrap:wrap;display:flex}.obs-title{color:var(--text-primary);letter-spacing:-.01em;margin:0 0 6px;font-size:28px;font-weight:700}.obs-subtitle{color:var(--text-muted);margin:0;font-size:14px}.obs-status-link{white-space:nowrap;align-items:center;gap:6px;font-size:13px;display:flex}.obs-loading{text-align:center;padding:var(--spacing-2xl);color:var(--text-muted);align-items:center;gap:var(--spacing-md);flex-direction:column;display:flex}.obs-error{align-items:center;gap:var(--spacing-md);padding:var(--spacing-xl);text-align:center;color:var(--accent-red);flex-direction:column;display:flex}.obs-empty{text-align:center;padding:80px var(--spacing-xl);color:var(--text-muted);align-items:center;gap:var(--spacing-md);flex-direction:column;display:flex}.obs-empty h3{color:var(--text-primary);margin:0}.obs-empty p{margin:0;font-size:14px}.obs-table{border-radius:var(--radius-lg);overflow:hidden}.obs-table-header{border-bottom:1px solid var(--border);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);background:#ffffff05;grid-template-columns:1fr 90px 70px 70px 70px 130px 120px 32px;gap:0;padding:10px 20px;font-size:10px;font-weight:600;display:grid}.obs-row-wrap{border-bottom:1px solid var(--border)}.obs-row-wrap:last-child{border-bottom:none}.obs-row{cursor:pointer;grid-template-columns:1fr 90px 70px 70px 70px 130px 120px 32px;align-items:center;gap:0;padding:14px 20px;transition:background .15s;display:grid}.obs-row:hover{background:#ffffff05}.obs-row.obs-row-expanded{background:#ffffff06}.obs-project-name{font-family:var(--font-mono);color:var(--text-primary);font-size:13px;font-weight:500}.obs-status-cell{align-items:center;gap:6px;display:flex}.obs-status-text{color:var(--text-secondary);font-size:12px}.obs-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.obs-dot-up{background:var(--accent-green);box-shadow:0 0 6px var(--accent-green)}.obs-dot-down{background:var(--accent-red);box-shadow:0 0 6px var(--accent-red)}.obs-dot-unknown{background:var(--text-muted)}.obs-uptime-badge{font-family:var(--font-mono);border-radius:999px;align-items:center;gap:4px;padding:2px 7px;font-size:11px;font-weight:600;display:inline-flex}.obs-badge-label{opacity:.7;font-size:9px}.obs-badge-green{color:#10b981;background:#10b9811f;border:1px solid #10b98140}.obs-badge-amber{color:#f59e0b;background:#f59e0b1f;border:1px solid #f59e0b40}.obs-badge-red{color:#ef4444;background:#ef44441f;border:1px solid #ef444440}.obs-badge-unknown{color:var(--text-muted);border:1px solid var(--border);background:#6b72801a}.obs-requests-cell{flex-direction:column;gap:2px;display:flex}.obs-req-count{font-family:var(--font-mono);color:var(--text-primary);font-size:13px}.obs-err-count{font-family:var(--font-mono);color:var(--accent-red);font-size:10px}.obs-last-checked{color:var(--text-muted);font-size:12px;font-family:var(--font-mono);align-items:center;gap:4px;display:flex}.obs-expand-icon{color:var(--text-muted);align-items:center;display:flex}.obs-detail{border-top:1px solid var(--border);gap:var(--spacing-lg);background:#00000026;flex-direction:column;padding:20px 20px 24px;display:flex}.obs-detail-loading{color:var(--text-muted);padding:20px;font-size:13px}.obs-detail-error{color:var(--accent-red);padding:16px 20px;font-size:13px}.obs-detail-section{flex-direction:column;gap:10px;display:flex}.obs-detail-heading{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:0;font-size:10px;font-weight:600}.obs-timeline{align-items:flex-end;gap:3px;height:32px;display:flex}.obs-bar{border-radius:2px;flex:1;min-width:4px;height:100%}.obs-bar-green{background:#10b98199}.obs-bar-amber{background:#f59e0b99}.obs-bar-red{background:#ef444499}.obs-bar-unknown{background:#6b728033}.obs-timeline-legend{gap:12px;display:flex}.obs-legend-item{font-size:10px;font-family:var(--font-mono);color:var(--text-muted);border-radius:4px;align-items:center;gap:5px;padding:2px 6px;display:flex}.obs-no-data{color:var(--text-muted);margin:0;font-size:13px}.obs-metrics-row{flex-wrap:wrap;gap:12px;display:flex}.obs-metric-chip{border:1px solid var(--border);border-radius:var(--radius-md);background:#ffffff08;flex-direction:column;gap:2px;min-width:100px;padding:10px 14px;display:flex}.obs-metric-chip.obs-metric-warn{background:#ef44440d;border-color:#ef44444d}.obs-metric-value{font-family:var(--font-mono);color:var(--text-primary);font-size:18px;font-weight:600}.obs-metric-chip.obs-metric-warn .obs-metric-value{color:var(--accent-red)}.obs-metric-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-size:10px}.obs-last-check-detail{color:var(--text-secondary);flex-wrap:wrap;align-items:center;gap:4px;margin:0;font-size:13px;display:flex}.obs-error-msg{color:var(--accent-red);font-size:12px}.obs-footer-note{color:var(--text-muted);margin-top:var(--spacing-md);font-size:12px;font-family:var(--font-mono);align-items:center;gap:5px;display:flex}@media (width<=768px){.obs-page{padding:var(--spacing-md)}.obs-table-header,.obs-row{grid-template-columns:1fr 80px 60px 32px}.obs-table-header span:nth-child(4),.obs-table-header span:nth-child(5),.obs-table-header span:nth-child(6),.obs-table-header span:nth-child(7),.obs-row>span:nth-child(4),.obs-row>span:nth-child(5),.obs-row>span:nth-child(6),.obs-row>span:nth-child(7){display:none}}.status-page{background:var(--bg-primary);flex-direction:column;min-height:100vh;animation:.3s fadeIn;display:flex}.status-header{border-bottom:1px solid var(--border);flex-direction:column;align-items:center;gap:12px;padding:20px 40px;display:flex}.status-logo{font-family:var(--font-mono);color:var(--text-muted);align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.status-headline{color:var(--text-primary);letter-spacing:-.02em;margin:0;font-size:32px;font-weight:700}.status-main{flex-direction:column;flex:1;gap:24px;width:100%;max-width:800px;margin:40px auto;padding:0 24px;display:flex}.status-loading{text-align:center;color:var(--text-muted);flex-direction:column;align-items:center;gap:12px;padding:60px 0;display:flex}.status-spinner{border:2px solid var(--border);border-top-color:var(--accent-green);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.status-banner{border-radius:var(--radius-lg);align-items:center;gap:10px;padding:16px 20px;font-size:15px;font-weight:600;display:flex}.status-banner-ok{color:#10b981;background:#10b98114;border:1px solid #10b98140}.status-banner-error{color:#ef4444;background:#ef444414;border:1px solid #ef444440}.status-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.status-table-header{border-bottom:1px solid var(--border);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);background:#ffffff05;grid-template-columns:1fr 140px 110px 100px;padding:10px 20px;font-size:10px;font-weight:600;display:grid}.status-row{border-bottom:1px solid var(--border);grid-template-columns:1fr 140px 110px 100px;align-items:center;padding:16px 20px;transition:background .15s;display:grid}.status-row:last-child{border-bottom:none}.status-row:hover{background:#ffffff05}.status-project-name{font-family:var(--font-mono);color:var(--text-primary);font-size:14px;font-weight:500}.status-state{align-items:center;gap:8px;display:flex}.dot-up{background:var(--accent-green);box-shadow:0 0 6px var(--accent-green)}.dot-down{background:var(--accent-red);box-shadow:0 0 6px var(--accent-red)}.dot-unknown{background:var(--text-muted)}.status-state-text{font-size:13px;font-weight:500}.text-up{color:var(--accent-green)}.text-down{color:var(--accent-red)}.status-uptime,.status-response{font-family:var(--font-mono);color:var(--text-secondary);font-size:13px}.status-updated{color:var(--text-muted);font-size:12px;font-family:var(--font-mono);align-items:center;gap:5px;display:flex}.status-no-projects{text-align:center;color:var(--text-muted);padding:40px 0;font-size:14px}.status-footer{text-align:center;color:var(--text-muted);border-top:1px solid var(--border);padding:24px;font-size:13px}.status-footer a{color:var(--accent-blue);text-decoration:none}.status-footer a:hover{text-decoration:underline}@media (width<=768px){.status-header{padding:16px 20px}.status-table-header,.status-row{grid-template-columns:1fr 120px 80px}.status-table-header span:last-child,.status-row>span:last-child{display:none}}.pd-page{gap:var(--spacing-md);width:100%;max-width:1400px;padding:var(--spacing-xl);flex-direction:column;margin:0 auto;animation:.3s fadeIn;display:flex}.pd-loading,.pd-error{min-height:300px;font-family:var(--font-mono);color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;font-size:13px;display:flex}.pd-resource-strip{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-md);-webkit-backdrop-filter:var(--glass-blur);flex-wrap:wrap;grid-area:1/2/auto/3;align-items:center;gap:28px;padding:10px 20px;display:flex}.pd-metric{flex-direction:column;gap:3px;min-width:90px;display:flex}.pd-metric-header{justify-content:space-between;align-items:baseline;gap:6px;display:flex}.pd-metric-label{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);font-size:9px}.pd-metric-value{font-family:var(--font-mono);color:var(--text-secondary);white-space:nowrap;font-size:11px}.pd-metric-unavailable{font-family:var(--font-mono);color:var(--text-muted);padding:4px 0;font-size:11px}.pd-layout{gap:var(--spacing-md);grid-template-rows:auto 1fr;grid-template-columns:150px 1fr 190px;align-items:start;display:grid}.pd-left{flex-direction:column;grid-area:2/1;gap:12px;display:flex;position:sticky;top:20px}.pd-back-link{font-family:var(--font-mono);color:var(--text-muted);transition:color var(--transition-fast);align-items:center;gap:5px;padding:3px 0;font-size:11px;text-decoration:none;display:inline-flex}.pd-back-link:hover{color:var(--text-secondary)}.pd-actions-group{flex-direction:column;gap:7px;display:flex}.pd-action-btn{justify-content:center;gap:6px;width:100%;font-size:12px}.pd-delete-btn{margin-top:4px}.pd-status-pill{justify-content:center;display:flex}.pd-center{gap:var(--spacing-md);grid-area:2/2/auto/3;grid-template-columns:300px 1fr;align-items:start;min-width:0;display:grid}.pd-info-stack{gap:var(--spacing-md);flex-direction:column;display:flex}.pd-info-card{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);padding:var(--spacing-lg);flex-direction:column;gap:5px;display:flex}.pd-name-row{align-items:center;gap:8px;margin-bottom:2px;display:flex}.pd-project-name{font-family:var(--font-mono);color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:16px;font-weight:700;overflow:hidden}.pd-ext-link{color:var(--text-muted);transition:color var(--transition-fast);flex-shrink:0;align-items:center;display:inline-flex}.pd-ext-link:hover{color:var(--accent-cyan)}.pd-project-url{font-family:var(--font-mono);color:var(--accent-cyan);text-overflow:ellipsis;white-space:nowrap;font-size:11px;text-decoration:none;overflow:hidden}.pd-project-url:hover{text-decoration:underline}.pd-project-url--custom{color:var(--text-muted);align-items:center;gap:4px;font-size:10px;display:flex}.pd-project-url--custom:hover{color:var(--text-secondary)}.pd-domain-dot{font-size:11px}.pd-domain-dot.status-active{color:var(--accent-green)}.pd-domain-dot.status-ssl_pending{color:var(--accent-cyan)}.pd-domain-dot.status-dns_pending,.pd-domain-dot.status-pending{color:var(--accent-amber)}.pd-meta-grid{border-top:1px solid var(--border);flex-wrap:wrap;gap:10px 18px;margin-top:4px;padding-top:8px;display:flex}.pd-meta-item{flex-direction:column;gap:2px;display:flex}.pd-meta-label{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;font-size:9px}.pd-meta-value{font-family:var(--font-mono);color:var(--text-secondary);white-space:nowrap;font-size:11px}.pd-previews-card{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);overflow:hidden}.pd-previews-toggle{cursor:pointer;width:100%;transition:background var(--transition-fast);background:0 0;border:none;align-items:center;gap:7px;padding:10px 14px;display:flex}.pd-previews-toggle:hover{background:#ffffff05}.pd-previews-count{background:var(--gradient-brand,linear-gradient(135deg, #3b82f6, #06b6d4));color:#fff;border-radius:var(--radius-full);text-align:center;min-width:16px;padding:1px 5px;font-size:9px}.pd-previews-chevron{color:var(--text-muted);align-items:center;margin-left:auto;display:flex}.pd-previews-body{border-top:1px solid var(--border);padding:4px 0}.pd-preview-row{align-items:center;gap:6px;padding:5px 12px;font-size:10px;display:flex}.pd-preview-row:hover{background:#ffffff05}.pd-pr-num{font-family:var(--font-mono);color:var(--accent-cyan);flex-shrink:0;min-width:26px;font-size:10px}.pd-pr-title{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.pd-pr-status{font-family:var(--font-mono);letter-spacing:.05em;text-transform:uppercase;border-radius:3px;flex-shrink:0;padding:1px 4px;font-size:8px}.pd-pr-status--building{color:var(--accent-amber);background:#f59e0b26;border:1px solid #f59e0b4d}.pd-pr-status--running{color:var(--accent-green);background:#10b9811f;border:1px solid #10b9814d}.pd-pr-status--failed{color:var(--accent-red);background:#ef44441f;border:1px solid #ef44444d}.pd-pr-url{font-family:var(--font-mono);color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;flex-shrink:1;min-width:0;font-size:9px;text-decoration:none;overflow:hidden}.pd-pr-url:hover{color:var(--accent-cyan)}.pd-pr-gh{font-family:var(--font-mono);color:var(--text-muted);border:1px solid var(--border);border-radius:3px;flex-shrink:0;padding:1px 4px;font-size:9px;text-decoration:none}.pd-pr-gh:hover{color:var(--text-primary)}.pd-pr-delete{color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast), background var(--transition-fast);background:0 0;border:none;border-radius:3px;flex-shrink:0;padding:2px 4px;font-size:10px}.pd-pr-delete:hover:not(:disabled){color:var(--accent-red);background:#ef44441a}.pd-pr-delete:disabled{opacity:.5;cursor:not-allowed}.pd-dynamic-panel{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);flex-direction:column;height:540px;display:flex;overflow:hidden}.pd-log-controls{align-items:center;gap:8px;display:flex}.pd-auto-refresh-label{font-family:var(--font-mono);color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:5px;font-size:10px;display:inline-flex}.pd-auto-refresh-label:hover{color:var(--text-secondary)}.pd-auto-refresh-check{width:11px;height:11px;accent-color:var(--accent-cyan);cursor:pointer}.pd-panel-empty-state{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:40px 24px;display:flex}.pd-panel-empty-icon{color:var(--text-muted);opacity:.3}.pd-panel-empty-state p{font-family:var(--font-mono);color:var(--text-muted);max-width:260px;font-size:12px;line-height:1.6}.pd-panel-generic{padding:var(--spacing-lg);flex-direction:column;flex:1;gap:14px;display:flex}.pd-panel-section-title{font-family:var(--font-mono);color:var(--text-primary);text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--border);padding-bottom:8px;font-size:11px;font-weight:600}.pd-panel-empty{font-family:var(--font-mono);color:var(--text-muted);font-size:11px}.pd-panel-note{font-style:italic}.pd-panel-action-btn{align-self:flex-start;gap:7px;font-size:12px}.pd-panel-logs{flex-direction:column;flex:1;display:flex;overflow:hidden}.pd-panel-toolbar{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.pd-log-type-tabs{gap:4px;display:flex}.pd-log-tab{border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-mono);color:var(--text-muted);cursor:pointer;text-transform:uppercase;letter-spacing:.05em;transition:color var(--transition-fast), border-color var(--transition-fast), background var(--transition-fast);background:0 0;padding:3px 9px;font-size:10px}.pd-log-tab.active{color:var(--accent-cyan);background:#06b6d412;border-color:#06b6d466}.pd-log-tab:hover:not(.active){color:var(--text-secondary)}.pd-log-body{font-family:var(--font-mono);background:#0a0e1480;flex:1;padding:12px 14px;font-size:10px;line-height:1.55;overflow-y:auto}.pd-log-line{word-break:break-all;margin-bottom:1px}.pd-log-default{color:var(--accent-green)}.pd-log-warn{color:var(--accent-amber)}.pd-log-error{color:var(--accent-red)}.pd-log-muted{color:var(--text-muted)}.pd-domain-info{flex-direction:column;gap:8px;display:flex}.pd-domain-row{align-items:center;gap:12px;display:flex}.pd-mono{font-family:var(--font-mono);color:var(--text-secondary);font-size:12px}.pd-domain-hint{font-family:var(--font-mono);color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius-sm);background:#ffffff08;margin-top:4px;padding:8px 10px;font-size:10px;line-height:1.6}.pd-env-list{border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:0;max-height:280px;display:flex;overflow:hidden auto}.pd-env-row{border-bottom:1px solid #ffffff0a;justify-content:space-between;align-items:center;gap:12px;padding:7px 10px;font-size:11px;display:flex}.pd-env-row:last-child{border-bottom:none}.pd-env-row:hover{background:#ffffff05}.pd-env-key{color:var(--accent-cyan);flex-shrink:0}.pd-env-val{font-family:var(--font-mono);color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.pd-limits-grid{flex-wrap:wrap;gap:20px;display:flex}.pd-limit-item{flex-direction:column;gap:4px;display:flex}.pd-limit-value{color:var(--text-primary);font-size:14px}.pd-panel-history{padding:var(--spacing-lg);flex-direction:column;flex:1;gap:14px;display:flex;overflow:hidden}.pd-history-list{border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;flex:1;min-height:0;display:flex;overflow-y:auto}.pd-history-row{font-family:var(--font-mono);border-bottom:1px solid #ffffff0a;align-items:center;gap:10px;padding:7px 10px;font-size:10px;display:flex}.pd-history-row:last-child{border-bottom:none}.pd-history-row:hover{background:#ffffff05}.pd-history-sha{color:var(--text-muted);flex-shrink:0;min-width:44px}.pd-history-branch{color:var(--accent-cyan);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.pd-history-trigger,.pd-history-time,.pd-history-dur{color:var(--text-muted);flex-shrink:0}.pd-right{flex-direction:column;grid-area:2/3;gap:6px;display:flex;position:sticky;top:20px}.pd-ql-heading{margin-bottom:2px;padding:0 2px}.pd-quicklinks{flex-direction:column;gap:3px;display:flex}.pd-ql-btn{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-md);width:100%;-webkit-backdrop-filter:var(--glass-blur);font-family:var(--font-sans);color:var(--text-secondary);cursor:pointer;text-align:left;transition:color var(--transition-fast), border-color var(--transition-fast), background var(--transition-fast);align-items:center;gap:8px;padding:8px 11px;font-size:12px;display:flex}.pd-ql-btn:hover{color:var(--text-primary);background:#06b6d40a;border-color:#06b6d440}.pd-ql-btn.active{color:var(--accent-cyan);background:#06b6d414;border-color:#06b6d466}.pd-ql-btn svg{color:var(--text-muted);transition:color var(--transition-fast);flex-shrink:0}.pd-ql-btn:hover svg,.pd-ql-btn.active svg{color:var(--accent-cyan)}.pd-section-label{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:10px}.pd-refresh-btn{color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;border-radius:4px;align-items:center;padding:2px 4px;display:inline-flex}.pd-refresh-btn:hover{color:var(--text-secondary)}.status-badge{font-family:var(--font-mono);border-radius:var(--radius-full);white-space:nowrap;align-items:center;gap:5px;padding:3px 8px;font-size:10px;font-weight:600;display:inline-flex}.status-dot{border-radius:50%;flex-shrink:0;width:5px;height:5px}.status-running{color:var(--accent-green);background:#10b9811f;border:1px solid #10b98140}.status-running .status-dot{background:var(--accent-green);animation:2s infinite pulse-green}.status-deploying{color:var(--accent-amber);background:#f59e0b1f;border:1px solid #f59e0b40}.status-deploying .status-dot{background:var(--accent-amber);animation:1.5s infinite pulse-green}.status-stopped{color:var(--text-muted);background:#6b5a7a1a;border:1px solid #6b5a7a2e}.status-stopped .status-dot{background:var(--text-muted)}.framework-badge{border-radius:var(--radius-full);font-family:var(--font-mono);color:var(--accent-cyan);white-space:nowrap;background:#06b6d412;border:1px solid #06b6d42e;align-items:center;padding:1px 6px;font-size:9px;display:inline-flex}@media (width<=1100px){.pd-layout{grid-template-columns:130px 1fr 170px}.pd-center{grid-template-columns:260px 1fr}}@media (width<=900px){.pd-layout{grid-template-rows:auto;grid-template-columns:1fr}.pd-resource-strip{grid-area:1/1}.pd-left{flex-flow:wrap;grid-area:2/1;align-items:center;position:static}.pd-center{grid-area:3/1;grid-template-columns:1fr}.pd-right{flex-flow:wrap;grid-area:4/1;position:static}.pd-actions-group{flex-direction:row}.pd-action-btn{width:auto}.pd-ql-btn{flex:1;width:auto;min-width:130px}}@media (width<=600px){.pd-page{padding:var(--spacing-md)}.pd-dynamic-panel{height:460px}}*{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#090010;--bg-card:#10041c8c;--bg-card-solid:#1e0a28;--bg-elevated:#321441b3;--bg-input:#14051ecc;--border:#9646ff21;--border-hover:#06b6d447;--border-active:#06b6d4b3;--accent-cyan:#06b6d4;--accent-violet:#7c3aed;--accent-green:#10b981;--accent-amber:#f59e0b;--accent-red:#ef4444;--gradient-brand:linear-gradient(135deg, #06b6d4, #7c3aed);--gradient-brand-hover:linear-gradient(135deg, #22d3ee, #8b5cf6);--gradient-brand-text:linear-gradient(135deg, #06b6d4, #8b5cf6);--glow-cyan:0 0 20px #06b6d466;--glow-violet:0 0 20px #7c3aed66;--glow-red:0 0 16px #ef444466;--text-primary:#ede8f5;--text-secondary:#a48cc4;--text-muted:#5e4d72;--font-sans:"DM Sans", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--radius-xs:4px;--radius-sm:10px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--spacing-2xl:48px;--transition-fast:.15s ease-out;--transition-base:.2s ease-out;--transition-slow:.3s ease-out;--glass-blur:blur(20px);--glass-bg:#10041c8c;--glass-border:1px solid #9646ff21;--glass-border-hover:#06b6d447;--glass-shadow:0 4px 24px #0000004d}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;line-height:1.6}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#7c3aed4d}::-webkit-scrollbar-thumb:hover{background:#7c3aed80}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse-green{0%,to{box-shadow:0 0 #10b98166}50%{box-shadow:0 0 0 6px #10b98100}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-100%)}to{opacity:1;transform:translate(0)}}@keyframes meshFloat{0%{transform:scale(1)translate(0)}to{transform:scale(1.06)translate(-2%,-2%)}}.btn{font-size:14px;font-weight:500;font-family:var(--font-sans);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;align-items:center;gap:6px;padding:8px 16px;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--gradient-brand);color:#fff}.btn-primary:hover:not(:disabled){background:var(--gradient-brand-hover);box-shadow:var(--glow-cyan);transform:translateY(-1px)}.btn-ghost{border:1px solid var(--border);color:var(--text-secondary);background:0 0}.btn-ghost:hover:not(:disabled){border-color:var(--border-hover);color:var(--text-primary);background:var(--bg-elevated)}.btn-ghost-green{color:#00ff88a6;background:0 0;border:1px solid #00ff8838}.btn-ghost-green:hover:not(:disabled){color:#0f8;background:#00ff8812;border-color:#00ff88a6;transform:translateY(-1px);box-shadow:0 0 14px #00ff882e}.btn-ghost-cyan{color:#00d4ffa6;background:0 0;border:1px solid #00d4ff38}.btn-ghost-cyan:hover:not(:disabled){color:#00d4ff;background:#00d4ff12;border-color:#00d4ffa6;transform:translateY(-1px);box-shadow:0 0 14px #00d4ff2e}.btn-ghost-amber{color:#ffb800a6;background:0 0;border:1px solid #ffb80038}.btn-ghost-amber:hover:not(:disabled){color:#ffb800;background:#ffb80012;border-color:#ffb800a6;transform:translateY(-1px);box-shadow:0 0 14px #ffb8002e}.btn-ghost-purple{color:#b44dffa6;background:0 0;border:1px solid #b44dff38}.btn-ghost-purple:hover:not(:disabled){color:#b44dff;background:#b44dff12;border-color:#b44dffa6;transform:translateY(-1px);box-shadow:0 0 14px #b44dff2e}.btn-ghost-orange{color:#ff6b35a6;background:0 0;border:1px solid #ff6b3538}.btn-ghost-orange:hover:not(:disabled){color:#ff6b35;background:#ff6b3512;border-color:#ff6b35a6;transform:translateY(-1px);box-shadow:0 0 14px #ff6b352e}.btn-secondary{border:1px solid var(--border);color:var(--text-secondary);background:0 0}.btn-secondary:hover:not(:disabled){border-color:var(--border-hover);color:var(--text-primary);background:var(--bg-elevated)}.btn-danger{color:var(--accent-red);background:0 0;border:1px solid #ef44444d}.btn-danger:hover:not(:disabled){box-shadow:var(--glow-red);background:#ef44441a}.btn-full{justify-content:center;width:100%}.btn-icon{flex-shrink:0;justify-content:center;width:34px;height:34px;padding:0}.input-glass{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;font-family:var(--font-sans);width:100%;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:10px 14px}.input-glass::placeholder{color:var(--text-muted)}.input-glass:focus{border-color:var(--accent-cyan);outline:none;box-shadow:0 0 0 3px #06b6d426}.glass-card{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur)}.spinner-small{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.6s linear infinite spin;display:inline-block}.btn-sm{padding:5px 10px;font-size:12px}.alert{border-radius:var(--radius-sm);margin-bottom:var(--spacing-md);border:1px solid #0000;align-items:center;gap:8px;padding:10px 14px;font-size:13px;display:flex}.alert-error{color:var(--accent-red);background:#ef444414;border-color:#ef44444d}.alert-success{color:var(--accent-green);background:#10b98114;border-color:#10b9814d}.alert-warning{color:var(--accent-amber);background:#f59e0b14;border-color:#f59e0b4d}.alert-info{color:var(--accent-cyan);background:#06b6d414;border-color:#06b6d44d}.section-description{color:var(--text-muted);margin:4px 0 0;font-size:13px}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;background:#120012d1;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-content{border:var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:#0e0418f7;flex-direction:column;width:100%;max-width:520px;max-height:90vh;display:flex;overflow-y:auto;box-shadow:0 24px 64px #0009,0 0 0 1px #06b6d414}.modal-header{border-radius:var(--radius-lg) var(--radius-lg) 0 0;background:#09001080;border-bottom:1px solid #9646ff1f;flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-title{font-family:var(--font-mono);color:var(--text-primary);margin:0;font-size:14px;font-weight:600}.modal-close{width:30px;height:30px;color:var(--text-muted);border-radius:var(--radius-xs);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:1px solid #9646ff21;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:18px;line-height:1;display:flex}.modal-close:hover{color:var(--accent-red);background:#ef44441a;border-color:#ef44444d}.modal-body{flex:1;padding:20px 24px}.modal-footer{border-radius:0 0 var(--radius-lg) var(--radius-lg);gap:var(--spacing-sm);background:#09001066;border-top:1px solid #9646ff1f;flex-shrink:0;justify-content:flex-end;padding:16px 24px;display:flex}.modal-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;font-family:var(--font-sans);width:100%;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);margin-bottom:var(--spacing-md);padding:10px 14px}.modal-input::placeholder{color:var(--text-muted)}.modal-input:focus{border-color:var(--accent-cyan);outline:none;box-shadow:0 0 0 3px #06b6d426}.modal-actions{gap:var(--spacing-sm);margin-top:var(--spacing-md);justify-content:flex-end;display:flex}.counter{color:var(--accent);background:var(--accent-bg);border:2px solid #0000;border-radius:5px;margin-bottom:24px;padding:5px 10px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}.env-modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;background:#120012d1;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.env-modal-content{-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:#160622f5;border:1px solid #b464ff33;border-radius:14px;flex-direction:column;width:100%;max-width:800px;max-height:90vh;display:flex;box-shadow:0 24px 64px #0009,0 0 0 1px #06b6d414}.env-modal-header{background:#12001266;border-bottom:1px solid #b464ff1f;border-radius:14px 14px 0 0;justify-content:space-between;align-items:flex-start;padding:24px;display:flex}.env-modal-header h2{color:#f0e8ff;font-size:20px;font-family:var(--font-sans,"DM Sans", sans-serif);margin:0 0 4px}.env-project-name{color:#6b5a7a;font-size:14px;font-family:var(--font-mono,"JetBrains Mono", monospace);margin:0}.env-close-btn{color:#6b5a7a;cursor:pointer;background:0 0;border:1px solid #b464ff26;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;padding:0;font-size:20px;transition:all .15s;display:flex}.env-close-btn:hover{color:#ef4444;background:#ef44441a;border-color:#ef44444d}.env-actions{border-bottom:1px solid #b464ff1a;gap:12px;padding:16px 24px;display:flex}.env-btn{cursor:pointer;font-size:14px;font-weight:500;font-family:var(--font-sans);border:1px solid #0000;border-radius:6px;padding:8px 16px;transition:all .15s}.env-btn-primary{color:#fff;background:linear-gradient(135deg,#06b6d4,#7c3aed);border-color:#0000}.env-btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#22d3ee,#8b5cf6);box-shadow:0 0 20px #06b6d466}.env-btn-secondary{color:#a78bca;background:0 0;border-color:#b464ff26}.env-btn-secondary:hover:not(:disabled){color:#f0e8ff;background:#321441b3;border-color:#06b6d466}.env-btn-save{color:#10b981;background:#10b98126;border-color:#10b9814d;margin-left:auto}.env-btn-save:hover:not(:disabled){background:#10b98140}.env-btn:disabled{opacity:.5;cursor:not-allowed}.env-form{background:#1200124d;border-bottom:1px solid #b464ff14;padding:16px 24px}.env-form-row{gap:12px;margin-bottom:12px;display:flex}.env-form-row:last-child{align-items:center;margin-bottom:0}.env-input{background:var(--bg-input);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px;font-family:var(--font-mono);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);border:1px solid #b464ff26;padding:10px 12px}.env-input:focus{border-color:var(--accent-cyan);outline:none;box-shadow:0 0 0 3px #06b6d41f}.env-input::placeholder{color:var(--text-muted)}.env-input-key{text-transform:uppercase;flex:0 0 200px}.env-input-value{flex:1}.env-checkbox-label{color:var(--text-muted);cursor:pointer;flex:1;align-items:center;gap:8px;font-size:13px;display:flex}.env-checkbox-label input[type=checkbox]{cursor:pointer;accent-color:var(--accent-cyan)}.env-import-form{background:#1200124d;border-bottom:1px solid #b464ff14;padding:16px 24px}.env-import-textarea{background:var(--bg-input);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-size:13px;font-family:var(--font-mono);resize:vertical;transition:border-color var(--transition-fast);border:1px solid #b464ff26;margin-bottom:12px;padding:12px}.env-import-textarea:focus{border-color:var(--accent-cyan);outline:none;box-shadow:0 0 0 3px #06b6d41f}.env-import-textarea::placeholder{color:var(--text-muted)}.env-list-container{flex:1;min-height:200px;padding:16px 24px;overflow-y:auto}.env-loading,.env-empty{text-align:center;color:var(--text-muted);font-family:var(--font-mono);padding:48px 24px;font-size:13px}.env-empty-hint{color:var(--text-muted);margin-top:8px;font-size:12px}.env-list{flex-direction:column;gap:10px;display:flex}.env-item{border-radius:var(--radius-sm);transition:border-color var(--transition-fast);background:#12041c80;border:1px solid #b464ff1a;grid-template-columns:1fr auto;align-items:center;gap:16px;padding:14px 16px;display:grid}.env-item:hover{border-color:#b464ff33}.env-item-content{flex-direction:column;gap:6px;min-width:0;display:flex}.env-item-key{font-family:var(--font-mono);color:var(--accent-cyan);letter-spacing:.5px;font-size:13px;font-weight:600}.env-item-value{font-family:var(--font-mono);color:var(--text-muted);align-items:center;gap:8px;font-size:12px;display:flex}.env-sensitive-badge{flex-shrink:0;font-size:11px}.env-delete-btn{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-xs);transition:all var(--transition-fast);background:0 0;border:1px solid #b464ff26;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;padding:0;font-size:16px;display:flex}.env-delete-btn:hover{color:var(--accent-red);background:#ef44441a;border-color:#ef44444d}.env-error{border-radius:var(--radius-sm);color:var(--accent-red);background:#ef444414;border:1px solid #ef44444d;margin-bottom:12px;padding:10px 14px;font-size:13px}.env-note{color:var(--text-muted);background:#06b6d40a;border-top:1px solid #b464ff14;flex-shrink:0;padding:14px 24px;font-size:13px;line-height:1.6}.env-note strong{color:var(--accent-cyan)}.logs-modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;background:#120012d1;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0}.logs-modal-content{border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:#12041cf7;border:1px solid #b464ff33;flex-direction:column;width:100%;max-width:1200px;max-height:90vh;display:flex;box-shadow:0 24px 64px #0009,0 0 0 1px #06b6d414}.logs-modal-header{border-radius:var(--radius-lg) var(--radius-lg) 0 0;background:#12001266;border-bottom:1px solid #b464ff1f;justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.logs-modal-header h2{font-family:var(--font-mono);color:var(--text-primary);margin:0;font-size:1rem;font-weight:600}.logs-close-btn{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-xs);width:30px;height:30px;transition:all var(--transition-fast);background:0 0;border:1px solid #b464ff26;justify-content:center;align-items:center;padding:0;font-size:1.25rem;line-height:1;display:flex}.logs-close-btn:hover{color:var(--accent-red);background:#ef44441a;border-color:#ef44444d}.logs-controls{background:#12001233;border-bottom:1px solid #b464ff14;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.5rem;display:flex}.logs-tabs{gap:.5rem;display:flex}.logs-tab{color:var(--text-muted);border-radius:var(--radius-xs);cursor:pointer;font-family:var(--font-mono);transition:all var(--transition-fast);background:0 0;border:1px solid #b464ff26;padding:6px 14px;font-size:.8125rem}.logs-tab:hover{color:var(--text-secondary);border-color:#06b6d44d}.logs-tab.active{border-color:var(--accent-cyan);color:var(--accent-cyan);background:#06b6d41f}.logs-actions{align-items:center;gap:1rem;display:flex}.logs-download-btn{color:var(--text-secondary);border-radius:var(--radius-xs);cursor:pointer;font-family:var(--font-mono);transition:all var(--transition-fast);background:0 0;border:1px solid #b464ff26;padding:6px 14px;font-size:.8125rem}.logs-download-btn:hover:not(:disabled){color:var(--accent-cyan);background:#06b6d40f;border-color:#06b6d466}.logs-download-btn:disabled{opacity:.4;cursor:not-allowed}.logs-autoscroll{color:var(--text-muted);font-family:var(--font-mono);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.5rem;font-size:.8125rem;display:flex}.logs-autoscroll input[type=checkbox]{cursor:pointer;accent-color:var(--accent-cyan)}.logs-container{background:#040008b3;flex:1;min-height:400px;padding:1rem;font-family:JetBrains Mono,monospace;font-size:.875rem;line-height:1.6;overflow-y:auto}.logs-loading,.logs-empty,.logs-error{color:var(--text-muted);text-align:center;font-family:var(--font-mono);flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:4rem 2rem;display:flex}.logs-loading-spinner{border:3px solid #b464ff26;border-top-color:var(--accent-cyan);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite logs-spinner}@keyframes logs-spinner{to{transform:rotate(360deg)}}.logs-error{color:var(--accent-red)}.logs-retry-btn{color:var(--text-secondary);border-radius:var(--radius-xs);cursor:pointer;font-family:var(--font-mono);transition:all var(--transition-fast);background:0 0;border:1px solid #b464ff33;padding:6px 20px;font-size:.875rem}.logs-retry-btn:hover{color:var(--accent-cyan);background:#06b6d40f;border-color:#06b6d466}.log-line{border-bottom:1px solid #b464ff0a;grid-template-columns:auto auto 1fr;gap:.75rem;padding:.25rem 0;display:grid}.log-line:last-child{border-bottom:none}.log-timestamp{color:var(--text-muted);white-space:nowrap;font-size:.8125rem}.log-level{white-space:nowrap;font-size:.8125rem;font-weight:600}.log-message{color:var(--text-secondary);word-break:break-word;white-space:pre-wrap}.logs-footer{border-radius:0 0 var(--radius-lg) var(--radius-lg);background:#12001266;border-top:1px solid #b464ff1f;justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.logs-count{color:var(--text-muted);font-family:var(--font-mono);font-size:.8125rem}.logs-refresh-indicator{color:var(--accent-cyan);font-family:var(--font-mono);align-items:center;gap:.5rem;font-size:.8125rem;display:flex}.logs-container::-webkit-scrollbar{width:6px}.logs-container::-webkit-scrollbar-track{background:0 0}.logs-container::-webkit-scrollbar-thumb{background:#7c3aed4d;border-radius:3px}.logs-container::-webkit-scrollbar-thumb:hover{background:#06b6d466}@media (width<=768px){.logs-modal-overlay{padding:1rem}.logs-modal-content{max-height:95vh}.logs-controls{flex-direction:column;align-items:stretch}.logs-tabs{width:100%}.logs-tab{text-align:center;flex:1}.logs-actions{justify-content:space-between;width:100%}.log-line{grid-template-columns:1fr;gap:.25rem}.log-timestamp,.log-level{font-size:.75rem}.logs-footer{flex-direction:column;align-items:flex-start;gap:.5rem}}.custom-domain-modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;background:#120012d1;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.custom-domain-modal-content{border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:#160622f5;border:1px solid #b464ff33;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px #0009,0 0 0 1px #06b6d414}.custom-domain-header{border-radius:var(--radius-lg) var(--radius-lg) 0 0;background:#12001266;border-bottom:1px solid #b464ff1f;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.custom-domain-header h2{color:var(--text-primary);font-size:16px;font-weight:600;font-family:var(--font-mono);margin:0}.custom-domain-close{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-xs);width:30px;height:30px;transition:all var(--transition-fast);background:0 0;border:1px solid #b464ff26;justify-content:center;align-items:center;padding:0;font-size:20px;line-height:1;display:flex}.custom-domain-close:hover{color:var(--accent-red);background:#ef44441a;border-color:#ef44444d}.custom-domain-body{padding:24px}.custom-domain-section{margin-bottom:24px}.custom-domain-section:last-child{margin-bottom:0}.custom-domain-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:10px;font-weight:600;font-family:var(--font-mono);margin-bottom:8px;display:block}.custom-domain-subdomain{background:var(--bg-input);border-radius:var(--radius-sm);border:1px solid #b464ff26;align-items:center;gap:12px;padding:12px;display:flex}.custom-domain-subdomain-text{font-family:var(--font-mono);color:var(--text-primary);flex:1;font-size:14px}.custom-domain-subdomain-badge{color:var(--accent-green);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-weight:600;font-family:var(--font-mono);background:#10b98126;border:1px solid #10b9814d;padding:3px 10px}.custom-domain-input-group{align-items:center;gap:12px;display:flex}.custom-domain-input{background:var(--bg-input);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-mono);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);border:1px solid #b464ff26;flex:1;padding:10px 14px;font-size:14px}.custom-domain-input:focus{border-color:var(--accent-cyan);outline:none;box-shadow:0 0 0 3px #06b6d426}.custom-domain-input:disabled{opacity:.5;cursor:not-allowed}.custom-domain-input::placeholder{color:var(--text-muted)}.custom-domain-status-badge{font-family:var(--font-mono);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;padding:4px 12px;font-size:10px;font-weight:600}.custom-domain-hint{color:var(--text-muted);margin:8px 0 0;font-size:13px;line-height:1.5}.custom-domain-error,.custom-domain-success{border-radius:6px;align-items:flex-start;gap:12px;margin-bottom:24px;padding:12px 16px;font-size:14px;line-height:1.5;display:flex}.custom-domain-error{color:#fca5a5;background:#ef44441a;border:1px solid #ef44444d}.custom-domain-success{color:#6ee7b7;background:#10b9811a;border:1px solid #10b9814d}.custom-domain-instructions{border-radius:var(--radius-sm);background:#12001266;border:1px solid #b464ff1f;margin-bottom:24px;padding:16px}.custom-domain-instructions h3{color:var(--text-primary);font-size:14px;font-weight:600;font-family:var(--font-mono);margin:0 0 12px}.custom-domain-instructions>p{color:var(--text-muted);margin:0 0 16px;font-size:13px;line-height:1.5}.custom-domain-dns-options{flex-direction:column;gap:12px;margin-bottom:16px;display:flex}.custom-domain-dns-option{border-radius:var(--radius-sm);background:#12041c99;border:1px solid #b464ff1f;padding:12px}.custom-domain-dns-option-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.custom-domain-dns-type{color:var(--text-secondary);font-size:12px;font-weight:600;font-family:var(--font-mono)}.custom-domain-dns-badge{color:var(--accent-cyan);border-radius:var(--radius-full);font-size:10px;font-weight:600;font-family:var(--font-mono);background:#06b6d41f;border:1px solid #06b6d440;padding:3px 8px}.custom-domain-dns-value{margin-bottom:8px}.custom-domain-dns-value code{border-radius:var(--radius-xs);color:var(--accent-cyan);font-family:var(--font-mono);background:#04000899;border:1px solid #b464ff1a;padding:8px 12px;font-size:12px;display:block;overflow-x:auto}.custom-domain-dns-description{color:var(--text-muted);margin:0;font-size:12px;line-height:1.5}.custom-domain-propagation-note{color:var(--accent-amber);border-radius:var(--radius-xs);background:#f59e0b14;border:1px solid #f59e0b33;margin:0;padding:8px 12px;font-size:13px}.custom-domain-footer{border-radius:0 0 var(--radius-lg) var(--radius-lg);background:#1200124d;border-top:1px solid #b464ff1f;padding:20px 24px}.custom-domain-actions{justify-content:flex-end;gap:12px;display:flex}.custom-domain-button{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);font-size:14px;font-weight:500;font-family:var(--font-sans);border:none;padding:9px 20px}.custom-domain-button:disabled{opacity:.5;cursor:not-allowed}.custom-domain-button-primary{color:#fff;background:linear-gradient(135deg,#06b6d4,#7c3aed);border:none}.custom-domain-button-primary:hover:not(:disabled){background:linear-gradient(135deg,#22d3ee,#8b5cf6);transform:translateY(-1px);box-shadow:0 0 20px #06b6d466}.custom-domain-button-secondary{color:var(--text-secondary);background:0 0;border:1px solid #b464ff26}.custom-domain-button-secondary:hover:not(:disabled){color:var(--text-primary);background:#ffffff0a;border-color:#06b6d466}.custom-domain-button-danger{color:var(--accent-red);background:0 0;border:1px solid #ef44444d}.custom-domain-button-danger:hover:not(:disabled){background:#ef44441a;box-shadow:0 0 16px #ef444433}@media (width<=640px){.custom-domain-modal-overlay{padding:16px}.custom-domain-modal-content{max-height:95vh}.custom-domain-header,.custom-domain-body,.custom-domain-footer{padding:16px}.custom-domain-actions{flex-direction:column}.custom-domain-button{width:100%}.custom-domain-input-group{flex-direction:column;align-items:stretch}.custom-domain-status-badge{text-align:center}}
