html,body{height:100%}*,*:before,*:after{box-sizing:border-box}:root{--onyx-bg: #0E0F13;--onyx-surface: #161821;--onyx-text: #E6E8EB;--onyx-muted: #9AA0A6;--onyx-accent: #C7C9CE;--onyx-border: rgba(199, 201, 206, .18);--onyx-border-strong: rgba(199, 201, 206, .28);--onyx-focus: rgba(199, 201, 206, .4)}body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";background:var(--onyx-bg);color:var(--onyx-text)}a{color:inherit}.container{max-width:1100px;margin:0 auto;padding:24px}.card{background:var(--onyx-surface);border:1px solid var(--onyx-border);border-radius:12px;padding:16px}.row{display:flex;gap:16px;align-items:center}.space-between{justify-content:space-between}.input{width:100%;padding:10px 12px;border-radius:10px;border:1px solid var(--onyx-border);background:#0e0f1359;color:var(--onyx-text)}.input:focus{outline:none;border-color:var(--onyx-border-strong);box-shadow:0 0 0 3px #c7c9ce1f}.button{padding:10px 12px;border-radius:10px;border:1px solid var(--onyx-border-strong);background:#c7c9ce1a;color:var(--onyx-text);cursor:pointer}.button:hover{background:#c7c9ce29}.button:disabled{opacity:.6;cursor:not-allowed}.button.secondary{background:#c7c9ce0f;border-color:var(--onyx-border)}.button.primary{background:#8b5cf6cc;border-color:#8b5cf699;color:#fff}.button.primary:hover{background:#8b5cf6}.badge{padding:4px 10px;border-radius:999px;border:1px solid var(--onyx-border);background:#c7c9ce0f;font-size:12px}.badge.live{border-color:#22c55e59;background:#22c55e1a}.badge.failed{border-color:#ef444459;background:#ef44441a}.badge.building{border-color:#eab30859;background:#eab3081a}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:12px;white-space:pre-wrap}.table{width:100%;border-collapse:collapse}.table th,.table td{text-align:left;padding:10px 8px;border-bottom:1px solid var(--onyx-border)}.hint{color:var(--onyx-muted);font-size:13px}.auth-root{min-height:100vh;width:100%;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:16px;background:var(--onyx-bg)}.auth-bg{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.auth-grid{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.03;background-image:linear-gradient(var(--onyx-text) 1px,transparent 1px),linear-gradient(90deg,var(--onyx-text) 1px,transparent 1px);background-size:50px 50px}.auth-content{position:relative;z-index:10;width:100%;max-width:480px}.auth-header{text-align:center;margin-bottom:32px}.auth-brand{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:12px;width:100%}.auth-brand-logo{width:auto;height:80px;display:block;object-fit:contain;max-width:100%;margin:0 auto}.auth-logo{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--onyx-accent) 0%,var(--onyx-muted) 100%);color:var(--onyx-bg)}.auth-logo-img{width:22px;height:22px;display:block;object-fit:contain}.auth-title{font-size:28px;font-weight:600;letter-spacing:-.02em;color:var(--onyx-text)}.auth-subtitle{font-size:14px;color:var(--onyx-muted)}.auth-card{position:relative;border-radius:16px;padding:32px;overflow:hidden;background:#161821b3;border:1px solid rgba(199,201,206,.1);box-shadow:0 24px 72px #0009;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.auth-card-glow{position:absolute;top:0;left:48px;right:48px;height:1px;background:linear-gradient(90deg,transparent,rgba(199,201,206,.3),transparent)}.auth-tabs{display:flex;gap:8px;margin-bottom:32px;padding:4px;border-radius:12px;background:#0e0f1399}.auth-tab{flex:1;padding:10px 16px;border-radius:10px;border:0;background:transparent;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.auth-tab.active{background:var(--onyx-surface);color:var(--onyx-text);box-shadow:0 2px 8px #0000004d}.auth-tab.inactive{color:var(--onyx-muted)}.auth-form{display:grid;gap:20px}.auth-field-label{display:block;font-size:13px;font-weight:500;margin-bottom:8px;color:var(--onyx-text)}.auth-field{position:relative;width:100%}.auth-icon-left{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--onyx-muted)}.auth-icon-right{position:absolute;right:16px;top:50%;transform:translateY(-50%);border:0;background:transparent;cursor:pointer;color:var(--onyx-muted);padding:0;display:flex;align-items:center;justify-content:center}.auth-input{width:100%;height:44px;display:block;border-radius:12px;padding:10px 16px 10px 48px;box-sizing:border-box;border:1px solid rgba(199,201,206,.1);background:#0e0f1399;color:var(--onyx-text);font-size:14px;line-height:20px;outline:none;transition:all .2s ease}.auth-input.with-right{padding-right:48px}.auth-input:focus{border-color:#c7c9ce4d;background:#0e0f13cc;box-shadow:0 0 0 3px #c7c9ce1a}.auth-actions{display:flex;justify-content:flex-end}.auth-link{border:0;background:transparent;cursor:pointer;font-size:13px;color:var(--onyx-muted);transition:color .15s ease}.auth-link:hover{color:var(--onyx-accent)}.auth-error{border-radius:12px;border:1px solid rgba(239,68,68,.35);background:#ef444414;padding:12px}.auth-submit{width:100%;border:0;border-radius:12px;padding:12px 16px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;font-size:14px;font-weight:500;color:var(--onyx-bg);background:linear-gradient(135deg,var(--onyx-accent) 0%,var(--onyx-muted) 100%);transition:box-shadow .2s ease}.auth-submit:disabled{opacity:.7;cursor:not-allowed}.auth-footer{margin-top:24px;text-align:center;font-size:12px;color:var(--onyx-muted)}.dash-root{min-height:100vh;width:100%;position:relative;overflow:hidden;background:var(--onyx-bg)}.dash-bg{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none}.dash-blob{position:absolute;top:0;right:0;width:33%;height:33%;border-radius:999px;filter:blur(100px);opacity:.1;background:radial-gradient(circle,var(--onyx-accent) 0%,transparent 70%)}.dash-grid{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.02;background-image:linear-gradient(var(--onyx-text) 1px,transparent 1px),linear-gradient(90deg,var(--onyx-text) 1px,transparent 1px);background-size:50px 50px}.dash-header{position:relative;z-index:5;border-bottom:1px solid rgba(199,201,206,.1);background:#16182180;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.dash-header-inner{max-width:1400px;margin:0 auto;padding:16px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px}.dash-brand{display:flex;align-items:center;gap:12px}.dash-brand-badge{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--onyx-accent) 0%,var(--onyx-muted) 100%)}.dash-brand-icon{width:20px;height:20px;color:var(--onyx-bg)}.dash-brand-title{font-size:16px;font-weight:600;color:var(--onyx-text);line-height:18px}.dash-brand-subtitle{font-size:11px;color:var(--onyx-muted);line-height:14px}.dash-nav{display:flex;align-items:center;gap:12px}.dash-tabs{display:flex;gap:6px;padding:4px;border-radius:12px;background:#0e0f1399;border:1px solid rgba(199,201,206,.08)}.dash-tab{display:inline-flex;align-items:center;justify-content:center;padding:8px 14px;border-radius:10px;font-size:13px;font-weight:500;color:var(--onyx-muted);text-decoration:none;transition:all .2s ease}.dash-tab:hover{color:var(--onyx-text)}.dash-tab-active{background:#c7c9ce26;color:var(--onyx-text)}.dash-logout{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:12px;background:#0e0f1399;border:1px solid rgba(199,201,206,.1);color:var(--onyx-muted);font-size:13px;font-weight:500;cursor:pointer;text-decoration:none;transition:all .2s ease}.dash-logout:hover{background:#0e0f13cc;border-color:#c7c9ce33;color:var(--onyx-text)}.dash-logout-icon{width:16px;height:16px}.polling-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#34d399;animation:polling-pulse 1.2s ease-in-out infinite}@keyframes polling-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.75)}}.plan-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;border:1px solid transparent}.plan-badge-free{background:#c7c9ce14;border-color:#c7c9ce26;color:var(--onyx-muted)}.plan-badge-hobby{background:#10b9811f;border-color:#10b9814d;color:#34d399}.plan-badge-pro{background:#8b5cf626;border-color:#8b5cf659;color:#a78bfa}.dash-content{position:relative;z-index:4;max-width:1400px;margin:0 auto;padding:28px 24px 72px}.dash-content-project{max-width:none;margin:0;padding:0}.dash-page{display:grid;gap:18px}.dash-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}@media (max-width: 900px){.dash-stats{grid-template-columns:1fr}}.dash-stat{position:relative;border-radius:16px;padding:18px;background:#16182180;border:1px solid rgba(199,201,206,.1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);cursor:pointer;overflow:hidden}.dash-stat-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.dash-stat-label{font-size:12px;font-weight:500;color:var(--onyx-muted);margin-bottom:6px}.dash-stat-value{font-size:28px;font-weight:600;color:var(--onyx-text);letter-spacing:-.02em}.dash-stat-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:#c7c9ce14}.dash-stat-icon-svg{width:20px;height:20px;color:var(--onyx-accent)}.dash-stat-success .dash-stat-icon-svg{color:#4ade80}.dash-stat-warning .dash-stat-icon-svg{color:#fcd34d}.dash-stat-underline{position:absolute;left:0;right:0;bottom:0;height:2px;opacity:0;transition:opacity .2s ease;background:linear-gradient(90deg,transparent,rgba(199,201,206,.6),transparent)}.dash-stat:hover .dash-stat-underline{opacity:1}.dash-stat-success .dash-stat-underline{background:linear-gradient(90deg,transparent,rgba(74,222,128,.9),transparent)}.dash-stat-warning .dash-stat-underline{background:linear-gradient(90deg,transparent,rgba(252,211,77,.9),transparent)}.dash-card{border-radius:16px;overflow:hidden;background:#16182180;border:1px solid rgba(199,201,206,.1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.dash-card-header{padding:18px;border-bottom:1px solid rgba(199,201,206,.1);display:flex;align-items:center;justify-content:space-between;gap:12px}.dash-card-title-row{display:flex;align-items:center;gap:10px}.dash-card-title-icon{width:18px;height:18px;color:var(--onyx-accent)}.dash-card-title{font-size:18px;font-weight:600;color:var(--onyx-text)}.dash-chip{padding:2px 8px;border-radius:999px;font-size:11px;font-weight:500;background:#c7c9ce26;color:var(--onyx-muted)}.dash-card-actions{display:flex;align-items:center;gap:10px}.dash-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border-radius:12px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid rgba(199,201,206,.1);transition:all .2s ease;-webkit-user-select:none;user-select:none}.dash-btn:disabled{opacity:.6;cursor:not-allowed}.dash-btn-icon{width:16px;height:16px}.dash-btn-ghost{background:#0e0f1399;color:var(--onyx-muted)}.dash-btn-ghost:hover{background:#0e0f13cc;color:var(--onyx-text)}.dash-btn-primary{background:linear-gradient(135deg,var(--onyx-accent) 0%,var(--onyx-muted) 100%);color:var(--onyx-bg);border-color:#c7c9ce1a}.dash-btn-primary:hover{box-shadow:0 12px 32px #00000059}.dash-card-body{padding:18px}.dash-error{border-radius:12px;border:1px solid rgba(239,68,68,.35);background:#ef444414;padding:12px;margin-bottom:12px}.dash-hint{color:var(--onyx-muted);font-size:13px;margin-bottom:10px}.dash-projects{display:grid;gap:10px}.dash-project{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px;border-radius:14px;text-decoration:none;background:#0e0f1366;border:1px solid rgba(199,201,206,.06);transition:all .18s ease}.dash-project:hover{background:#0e0f1399;border-color:#c7c9ce26}.dash-project-left{display:flex;align-items:center;gap:14px;min-width:0;flex:1}.dash-project-badge{width:44px;height:44px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:#c7c9ce1a}.dash-project-badge-icon{width:22px;height:22px;color:var(--onyx-accent)}.dash-project-meta{min-width:0;flex:1}.dash-project-name{font-size:15px;font-weight:500;color:var(--onyx-text);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-project-sub{display:flex;align-items:center;gap:10px;color:var(--onyx-muted);font-size:12px;white-space:nowrap;overflow:hidden}.dash-dot{width:4px;height:4px;border-radius:999px;background:#c7c9ce59;flex:0 0 auto}.dash-project-slug{overflow:hidden;text-overflow:ellipsis}.dash-project-last{display:inline-flex;align-items:center;gap:6px;flex:0 0 auto}.dash-project-clock{width:13px;height:13px}.dash-project-chevron{width:20px;height:20px;color:var(--onyx-muted);opacity:.8}.dash-empty{text-align:center;padding:40px 0;display:grid;justify-items:center;gap:10px}.dash-empty-icon{width:56px;height:56px;border-radius:999px;display:flex;align-items:center;justify-content:center;background:#c7c9ce1a}.dash-empty-icon-svg{width:28px;height:28px;color:var(--onyx-muted)}.dash-empty-title{font-size:16px;font-weight:600;color:var(--onyx-text)}.dash-empty-subtitle{font-size:13px;color:var(--onyx-muted)}.dash-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;isolation:isolate;display:flex;align-items:flex-start;justify-content:center;padding:96px 24px 24px;overflow:auto}.dash-modal-backdrop:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:#06070a99;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:0;pointer-events:none}.dash-modal{position:relative;top:auto;left:auto;transform:none;width:min(720px,calc(100vw - 48px));border-radius:18px;background:#0a0b0eeb;border:1px solid rgba(199,201,206,.12);box-shadow:0 18px 70px #000000a6;overflow:hidden;-webkit-backdrop-filter:none;backdrop-filter:none;max-height:calc(100vh - 48px);display:flex;flex-direction:column;z-index:1}.dash-modal-header{padding:18px;border-bottom:1px solid rgba(199,201,206,.1);display:flex;align-items:center;justify-content:space-between;gap:12px}.dash-modal-titlewrap{display:flex;align-items:center;gap:12px}.dash-modal-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:#c7c9ce26}.dash-modal-icon-svg{width:20px;height:20px;color:var(--onyx-accent)}.dash-modal-title{font-size:16px;font-weight:600;color:var(--onyx-text);margin-bottom:2px}.dash-modal-subtitle{font-size:12px;color:var(--onyx-muted)}.dash-modal-close{width:34px;height:34px;border-radius:12px;border:1px solid rgba(199,201,206,.1);background:#0e0f1399;color:var(--onyx-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .18s ease}.dash-modal-close:hover{background:#0e0f13cc;color:var(--onyx-text)}.dash-modal-close-icon{width:16px;height:16px}.dash-modal-body{padding:18px;overflow:auto}.dash-form{display:grid;gap:12px}.dash-envlist{display:grid;gap:10px}.dash-envrow{display:grid;grid-template-columns:1fr 1fr auto;gap:10px;align-items:center}@media (max-width: 720px){.dash-envrow{grid-template-columns:1fr}}.dash-label{font-size:13px;font-weight:500;margin-bottom:8px;color:var(--onyx-text)}.dash-input{width:100%;min-height:44px;border-radius:12px;padding:10px 14px;box-sizing:border-box;border:1px solid rgba(199,201,206,.1);background:#0e0f1399;color:var(--onyx-text);font-size:14px;font-family:inherit;outline:none;transition:all .2s ease}.dash-input:focus{border-color:#c7c9ce4d;background:#0e0f13cc;box-shadow:0 0 0 3px #c7c9ce1a}.dash-modal-actions{display:flex;gap:12px;margin-top:6px}.dash-product-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width: 720px){.dash-product-grid{grid-template-columns:1fr}}.dash-product{text-align:left;border-radius:14px;padding:14px;border:1px solid rgba(199,201,206,.12);background:#0e0f138c;cursor:pointer;color:var(--onyx-text);transition:border-color .16s ease,background .16s ease,transform .16s ease}.dash-product:hover{background:#0e0f13bf;border-color:#c7c9ce38}.dash-product:focus{outline:none;box-shadow:0 0 0 3px #c7c9ce1a}.dash-product-selected{border-color:#4ade808c;box-shadow:0 0 0 3px #4ade801f}.dash-product-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}.dash-product-title{font-size:14px;font-weight:600}.dash-product-badge{font-size:11px;padding:2px 8px;border-radius:999px;border:1px solid rgba(199,201,206,.18);background:#c7c9ce14;color:var(--onyx-accent)}.dash-product-sub{font-size:12px;color:var(--onyx-muted);line-height:16px}.proj-shell{display:grid;grid-template-columns:240px 1fr;gap:14px}@media (max-width: 900px){.proj-shell{grid-template-columns:1fr}}.proj-sidebar{border:1px solid rgba(199,201,206,.1);border-radius:16px;background:#0a0b0eb3;padding:14px}.proj-title{font-weight:700;color:var(--onyx-text);margin-bottom:2px}.proj-sub{font-size:12px;color:var(--onyx-muted);margin-bottom:12px}.proj-tabs{display:grid;gap:8px}.proj-tab{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-radius:12px;border:1px solid rgba(199,201,206,.1);background:#0e0f138c;color:var(--onyx-text);cursor:pointer}.proj-tab:hover{background:#0e0f13cc;border-color:#c7c9ce2e}.proj-tab-active{border-color:#4ade8066;box-shadow:0 0 0 3px #4ade801a}.proj-main{border:1px solid rgba(199,201,206,.1);border-radius:16px;background:#0a0b0eb3;padding:14px}.proj-section-title{font-weight:700;margin-bottom:10px}.proj-root{min-height:100vh;width:100%;display:flex;background:#0e0f13;position:relative}.proj-bg{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none}.proj-blob{position:absolute;top:0;left:0;width:34%;height:34%;border-radius:999px;filter:blur(100px);opacity:.1;background:radial-gradient(circle,#C7C9CE 0%,transparent 70%)}.proj-grid{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.02;background-image:linear-gradient(#E6E8EB 1px,transparent 1px),linear-gradient(90deg,#E6E8EB 1px,transparent 1px);background-size:50px 50px}.proj-shell{position:relative;display:flex;flex:1;z-index:1;gap:0}.proj-sidebar{width:280px;flex-shrink:0;border:none;border-right:1px solid rgba(199,201,206,.1);border-radius:0;padding:0;background:#16182180;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.proj-sidebar-inner{padding:24px;display:flex;flex-direction:column;height:100%;gap:16px}.proj-back{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--onyx-muted);text-decoration:none;transition:color .18s ease}.proj-back:hover{color:var(--onyx-text)}.proj-back-icon{width:16px;height:16px}.proj-info{display:flex;align-items:center;gap:12px}.proj-info-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:#c7c9ce26}.proj-info-icon-svg{width:20px;height:20px;color:#c7c9ce}.proj-info-text{flex:1;min-width:0}.proj-info-title{font-size:16px;font-weight:600;color:var(--onyx-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.proj-info-sub{font-size:12px;color:var(--onyx-muted);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.proj-nav{display:grid;gap:4px}.proj-navbtn{width:100%;padding:10px 16px;border-radius:12px;border:1px solid transparent;background:transparent;color:var(--onyx-muted);font-size:13px;font-weight:500;text-align:left;display:flex;align-items:center;gap:8px;cursor:pointer;transition:background .18s ease,color .18s ease}.proj-navbtn:hover{background:#c7c9ce14;color:var(--onyx-text)}.proj-navbtn-active{background:#c7c9ce26;color:var(--onyx-text)}.proj-navbtn-icon{width:16px;height:16px}.proj-services{display:grid;gap:10px;flex:1;align-content:start;grid-auto-rows:max-content}.proj-services-title{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--onyx-muted);margin-top:6px}.proj-service{padding:12px;border-radius:12px;border:1px solid rgba(199,201,206,.1);background:#0e0f1399;text-align:left;cursor:pointer;color:var(--onyx-text)}.proj-service:hover{background:#0e0f13bf;border-color:#c7c9ce29}.proj-service-top{display:flex;justify-content:space-between;align-items:center}.proj-service-name{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:500}.proj-service-icon{width:16px;height:16px}.proj-service-status{display:inline-flex;align-items:center;gap:6px;margin-top:6px;font-size:11px}.proj-service-status-icon{width:12px;height:12px}.proj-refresh{width:100%;padding:10px 14px;border-radius:12px;border:1px solid rgba(199,201,206,.1);background:#0e0f1399;color:var(--onyx-muted);display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer}.proj-refresh:hover{background:#0e0f13cc;color:var(--onyx-text)}.proj-refresh-icon{width:16px;height:16px}.proj-main{flex:1;overflow-y:auto;border:none;border-radius:0;padding:0 32px 24px;background:transparent}.proj-main-header{max-width:1200px;margin:0 auto;padding:32px 0 0}.proj-main-title{font-size:24px;font-weight:600;color:var(--onyx-text);margin-bottom:6px}.proj-main-sub{font-size:14px;color:var(--onyx-muted)}.proj-card{max-width:1200px;margin:18px auto 0;border-radius:14px;overflow:hidden;background:#16182180;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(199,201,206,.1)}.proj-card-inner{padding:24px}.proj-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px}.proj-card-titlewrap{display:flex;align-items:center;gap:12px}.proj-card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:#c7c9ce1a}.proj-card-icon-svg{width:24px;height:24px;color:#c7c9ce}.proj-card-title{font-size:16px;font-weight:600;color:var(--onyx-text);margin-bottom:4px}.proj-pill{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:500;background:#c7c9ce26;color:#c7c9ce}.proj-ghostbtn{padding:10px 12px;border-radius:12px;border:1px solid rgba(199,201,206,.1);background:#0e0f1399;color:var(--onyx-muted);cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:background .18s ease,color .18s ease}.proj-ghostbtn:hover{background:#0e0f13cc;color:var(--onyx-text)}.proj-ghostbtn-icon{width:14px;height:14px}.proj-statusrow{border-radius:12px;background:#0e0f1399;padding:14px;display:flex;align-items:center;gap:12px}.proj-status-icon{width:20px;height:20px}.proj-status-title{font-size:13px;font-weight:500;color:var(--onyx-text);margin-bottom:2px}.proj-status-sub{font-size:12px;color:var(--onyx-muted)}.proj-card-meta{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:var(--onyx-muted)}.proj-card-meta-icon{width:14px;height:14px}.proj-soon{padding:6px 10px;border-radius:10px;font-size:11px;font-weight:500;background:#fcd34d26;color:#fcd34d}.proj-note{border-radius:12px;background:#0e0f1399;padding:18px;text-align:center;margin-bottom:14px}.proj-note-title{font-size:14px;font-weight:500;color:var(--onyx-text);margin-bottom:4px}.proj-note-sub{font-size:12px;color:var(--onyx-muted)}.proj-metrics{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media (max-width: 900px){.proj-metrics{grid-template-columns:1fr}}.proj-metric{border-radius:12px;padding:14px;background:#0e0f1366;border:1px solid rgba(199,201,206,.05)}.proj-metric-label{font-size:11px;font-weight:500;color:var(--onyx-muted);margin-bottom:10px}.proj-metric-value{font-size:24px;font-weight:600;color:var(--onyx-text)}.proj-actions{max-width:1200px;margin:18px auto 24px;padding:0;display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}@media (max-width: 900px){.proj-actions{grid-template-columns:1fr}}.proj-action{padding:16px;border-radius:14px;text-align:left;border:1px solid rgba(199,201,206,.1);background:#16182180;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);cursor:pointer;color:var(--onyx-text);transition:background .18s ease,border-color .18s ease}.proj-action:hover{background:#161821b3;border-color:#c7c9ce33}.proj-action-icon{width:20px;height:20px;margin-bottom:12px}.proj-action-label{font-size:13px;font-weight:500}.dep-attach-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.dep-attach-left{display:grid;gap:4px}.dep-attach-title{font-size:14px;font-weight:600;color:var(--onyx-text)}.dep-attach-sub{font-size:12px;color:var(--onyx-muted)}.dep-attach-row{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;margin-bottom:8px}@media (max-width: 900px){.dep-attach-row{grid-template-columns:1fr}}.dep-history-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.dep-history-titlewrap{display:flex;align-items:center;gap:10px}.dep-history-title{font-size:14px;font-weight:600;color:var(--onyx-text)}.dep-empty{min-height:180px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;border-radius:12px;background:#0e0f1359;border:1px solid rgba(199,201,206,.08)}.dep-empty-icon{width:42px;height:42px;border-radius:999px;display:flex;align-items:center;justify-content:center;background:#c7c9ce1a}.dep-empty-icon-svg{width:18px;height:18px;color:var(--onyx-accent)}.dep-empty-title{font-size:13px;font-weight:600;color:var(--onyx-text)}.dep-empty-sub{font-size:12px;color:var(--onyx-muted);text-align:center;max-width:380px;line-height:16px}.db-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.db-head-left{display:grid;gap:8px}.db-head-meta{display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap}.db-status{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600;border:1px solid rgba(199,201,206,.12);background:#c7c9ce14;color:var(--onyx-muted)}.db-status-ready{background:#4ade801f;border-color:#4ade8038;color:#4ade80}.db-status-warn{background:#fcd34d1f;border-color:#fcd34d38;color:#fcd34d}.db-status-off{opacity:.8}.db-conn{font-size:12px;color:var(--onyx-muted)}.db-tabs{display:flex;align-items:center;gap:6px;max-width:1200px;margin:12px auto 0}.db-tab{padding:8px 12px;border-radius:999px;border:1px solid rgba(199,201,206,.1);background:#0e0f1373;color:var(--onyx-muted);font-size:12px;font-weight:600;cursor:pointer}.db-tab:hover{color:var(--onyx-text);background:#0e0f13a6}.db-tab-active{background:#c7c9ce26;color:var(--onyx-text)}.db-card-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.db-card-title{font-size:13px;font-weight:700;color:var(--onyx-text)}.db-sql{width:100%;min-height:220px;resize:vertical;border-radius:12px;border:1px solid rgba(199,201,206,.1);background:#0e0f1373;color:var(--onyx-text);padding:12px;outline:none;font-size:12px;line-height:18px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.db-tablebar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.db-select{flex:1;border-radius:12px;border:1px solid rgba(199,201,206,.1);background:#0e0f1373;color:var(--onyx-text);padding:10px 12px;outline:none}.db-tablewrap{border-radius:12px;border:1px solid rgba(199,201,206,.08);background:#0e0f1340;overflow:auto;max-height:380px}@media (max-width: 900px){.proj-sidebar{width:100%;border-right:none;border-bottom:1px solid rgba(199,201,206,.1)}.proj-shell{flex-direction:column}.proj-main{padding:0 18px 18px}.proj-main-header{padding:24px 0 0}.proj-card{margin-left:18px;margin-right:18px}.proj-actions{padding:0}}
