:root{--bg: #fafaf8;--bg-card: #ffffff;--bg-hover: #f4f4f0;--bg-input: #f4f4f0;--border: #e2e0db;--border-focus: #1a1a1a;--text: #1a1a1a;--text-secondary: #6b6860;--text-tertiary: #9b978f;--accent: #2d5a27;--accent-light: #e8f0e6;--danger: #c23b22;--danger-light: #fce8e4;--warning: #b5830a;--warning-light: #fef6e0;--success: #2d5a27;--success-light: #e8f0e6;--mono: "JetBrains Mono", monospace;--sans: "DM Sans", -apple-system, sans-serif;--radius: 8px;--shadow: 0 1px 3px rgba(0,0,0,.04), 0 1px 2px rgba(0,0,0,.06);--shadow-lg: 0 4px 12px rgba(0,0,0,.06), 0 1px 3px rgba(0,0,0,.08)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.5}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.layout{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--bg-card);border-right:1px solid var(--border);padding:24px 0;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:10}.sidebar-logo{font-size:20px;font-weight:700;letter-spacing:-.5px;padding:0 24px;margin-bottom:32px;color:var(--text)}.sidebar-logo span{color:var(--accent)}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:2px;padding:0 12px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:6px;color:var(--text-secondary);font-size:14px;font-weight:500;transition:all .15s;cursor:pointer;border:none;background:none;width:100%;text-align:left;text-decoration:none}.sidebar-link:hover{background:var(--bg-hover);color:var(--text);text-decoration:none}.sidebar-link.active{background:var(--accent-light);color:var(--accent)}.sidebar-footer{padding:16px 24px;border-top:1px solid var(--border);margin-top:auto}.sidebar-user{font-size:13px;color:var(--text-secondary)}.main{flex:1;margin-left:240px;padding:32px 40px;max-width:1100px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}.page-title{font-size:24px;font-weight:700;letter-spacing:-.5px}.page-subtitle{font-size:14px;color:var(--text-secondary);margin-top:4px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius);font-size:14px;font-weight:500;font-family:var(--sans);cursor:pointer;border:1px solid var(--border);background:var(--bg-card);color:var(--text);transition:all .15s}.btn:hover{background:var(--bg-hover)}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{opacity:.9;background:var(--accent)}.btn-danger{background:var(--bg-card);color:var(--danger);border-color:var(--danger)}.btn-danger:hover{background:var(--danger-light)}.btn-sm{padding:5px 10px;font-size:13px}.btn:disabled{opacity:.5;cursor:not-allowed}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}.card+.card{margin-top:12px}.project-card{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;transition:all .15s;cursor:pointer}.project-card:hover{border-color:var(--text-tertiary);box-shadow:var(--shadow-lg)}.project-name{font-weight:600;font-size:15px;margin-bottom:2px}.project-meta{font-size:13px;color:var(--text-secondary);font-family:var(--mono)}.project-url{font-size:12px;color:var(--text-tertiary);font-family:var(--mono)}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:100px;font-size:12px;font-weight:500}.badge-live{background:var(--success-light);color:var(--success)}.badge-building{background:var(--warning-light);color:var(--warning)}.badge-failed{background:var(--danger-light);color:var(--danger)}.badge-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.badge-live .badge-dot{animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.form-group{margin-bottom:16px}.form-label{display:block;font-size:13px;font-weight:500;margin-bottom:6px;color:var(--text-secondary)}.form-input,.form-select,.form-textarea{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;font-family:var(--sans);background:var(--bg-input);color:var(--text);transition:border-color .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--border-focus)}.form-input-mono{font-family:var(--mono);font-size:13px}.form-textarea{min-height:100px;resize:vertical}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th{text-align:left;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);padding:8px 12px;border-bottom:1px solid var(--border)}td{padding:12px;border-bottom:1px solid var(--border);font-size:14px;vertical-align:middle}tr:last-child td{border-bottom:none}.log-viewer{background:#1a1a1a;color:#e0ddd5;font-family:var(--mono);font-size:12px;line-height:1.7;padding:16px;border-radius:var(--radius);overflow-x:auto;max-height:500px;overflow-y:auto;white-space:pre-wrap;word-break:break-all}.env-row{display:flex;gap:8px;margin-bottom:8px;align-items:center}.env-row .form-input{flex:1}.env-row .form-input:first-child{max-width:200px}.empty{text-align:center;padding:60px 20px;color:var(--text-secondary)}.empty-icon{font-size:40px;margin-bottom:12px;opacity:.3}.empty-title{font-size:16px;font-weight:600;color:var(--text);margin-bottom:4px}.empty-text{font-size:14px;margin-bottom:20px}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg)}.login-card{text-align:center;padding:48px;max-width:400px;width:100%}.login-logo{font-size:32px;font-weight:700;letter-spacing:-1px;margin-bottom:8px}.login-logo span{color:var(--accent)}.login-tagline{font-size:15px;color:var(--text-secondary);margin-bottom:40px}.btn-github{width:100%;padding:12px;font-size:15px;justify-content:center;background:#1a1a1a;color:#fff;border-color:#1a1a1a}.btn-github:hover{background:#333}.btn-github svg{width:20px;height:20px}.tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:24px}.tab{padding:10px 16px;font-size:14px;font-weight:500;color:var(--text-secondary);border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;font-family:var(--sans)}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--bg-card);border-radius:12px;padding:32px;max-width:520px;width:90%;box-shadow:var(--shadow-lg)}.modal-title{font-size:18px;font-weight:700;margin-bottom:20px}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:24px}.toast{position:fixed;bottom:24px;right:24px;padding:12px 20px;border-radius:var(--radius);font-size:14px;font-weight:500;box-shadow:var(--shadow-lg);z-index:200;animation:slideUp .3s ease}.toast-success{background:var(--success);color:#fff}.toast-error{background:var(--danger);color:#fff}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.flex{display:flex}.flex-col{flex-direction:column}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-4{margin-bottom:16px}.text-sm{font-size:13px}.text-secondary{color:var(--text-secondary)}.text-mono{font-family:var(--mono)}.text-right{text-align:right}.w-full{width:100%}.loading{display:flex;align-items:center;justify-content:center;padding:60px;color:var(--text-tertiary)}
