*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0f1117;color:#e1e4e8;height:100vh}#root{height:100vh;display:flex;flex-direction:column}.app{display:flex;flex-direction:column;height:100vh}.auth-loading{display:flex;align-items:center;justify-content:center;height:100vh;font-size:1.2rem;color:#8b949e}.login-screen{display:flex;align-items:center;justify-content:center;height:100vh;background:#0f1117}.login-card{text-align:center;padding:3rem;background:#161b22;border:1px solid #30363d;border-radius:12px;max-width:400px}.login-card h1{font-size:2rem;margin-bottom:.5rem;color:#58a6ff}.login-card p{color:#8b949e;margin-bottom:2rem}.login-button{padding:.75rem 2rem;background:#238636;color:#fff;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:background .2s}.login-button:hover{background:#2ea043}.header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;background:#161b22;border-bottom:1px solid #30363d}.header-left{display:flex;align-items:center;gap:1rem}.header h1{font-size:1.25rem;color:#58a6ff}.header-solution-label{padding:.25rem .75rem;background:#1f6feb22;color:#58a6ff;border-radius:12px;font-size:.8rem}.header-right{display:flex;align-items:center;gap:1rem}.user-name{color:#8b949e;font-size:.875rem}.logout-button{padding:.375rem .75rem;background:transparent;color:#8b949e;border:1px solid #30363d;border-radius:6px;cursor:pointer;font-size:.8rem}.logout-button:hover{color:#e1e4e8;border-color:#8b949e}.main{flex:1;overflow:hidden;display:flex;flex-direction:column}.loading{display:flex;align-items:center;justify-content:center;height:100%;color:#8b949e}.selector{max-width:900px;margin:0 auto;padding:3rem 1.5rem}.selector h2{font-size:1.75rem;margin-bottom:.5rem}.selector-subtitle{color:#8b949e;margin-bottom:2rem}.type-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.type-card{background:#161b22;border:1px solid #30363d;border-radius:8px;padding:1.5rem;cursor:pointer;text-align:left;color:#e1e4e8;transition:border-color .2s,transform .1s}.type-card:hover{border-color:#58a6ff;transform:translateY(-2px)}.type-card h3{font-size:1.1rem;margin-bottom:.5rem;color:#58a6ff}.type-card p{color:#8b949e;font-size:.875rem;line-height:1.4}.chat{flex:1;display:flex;flex-direction:column;max-width:800px;margin:0 auto;width:100%;height:100%}.messages{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.message{max-width:85%}.message-user{align-self:flex-end}.message-assistant{align-self:flex-start}.message-label{font-size:.75rem;color:#8b949e;margin-bottom:.25rem;padding:0 .25rem}.message-user .message-label{text-align:right}.message-content{padding:.75rem 1rem;border-radius:12px;line-height:1.5;font-size:.95rem}.message-user .message-content{background:#1f6feb;color:#fff;border-bottom-right-radius:4px}.message-assistant .message-content{background:#21262d;border:1px solid #30363d;border-bottom-left-radius:4px}.message-content p{margin-bottom:.5rem}.message-content p:last-child{margin-bottom:0}.typing{color:#8b949e;font-style:italic}.chat-spec-bar{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;background:#23863622;border-top:1px solid #23863644;color:#3fb950;font-size:.9rem;font-weight:500}.chat-spec-bar .button-primary{padding:.5rem 1rem;font-size:.85rem}.chat-input{display:flex;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid #30363d;background:#161b22}.chat-input input{flex:1;padding:.75rem 1rem;background:#0d1117;border:1px solid #30363d;border-radius:8px;color:#e1e4e8;font-size:.95rem;outline:none}.chat-input input:focus{border-color:#58a6ff}.chat-input button{padding:.75rem 1.5rem;background:#238636;color:#fff;border:none;border-radius:8px;font-size:.95rem;cursor:pointer;transition:background .2s}.chat-input button:hover:not(:disabled){background:#2ea043}.chat-input button:disabled{opacity:.5;cursor:not-allowed}.spec-review{max-width:800px;margin:0 auto;padding:2rem 1.5rem;overflow-y:auto;flex:1}.spec-review h2{margin-bottom:.5rem}.spec-subtitle{color:#8b949e;margin-bottom:1.5rem}.spec-card{background:#161b22;border:1px solid #30363d;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.spec-title-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.spec-title{font-size:1.25rem;cursor:pointer}.spec-title:hover{color:#58a6ff}.edit-hint{font-size:.8rem;color:#484f58}.spec-title:hover .edit-hint{color:#58a6ff}.spec-title-input{font-size:1.25rem;font-weight:600;background:#0d1117;border:1px solid #58a6ff;border-radius:6px;color:#e1e4e8;padding:.25rem .5rem;outline:none;flex:1}.spec-type-badge{display:inline-block;padding:.25rem .75rem;background:#1f6feb22;color:#58a6ff;border-radius:12px;font-size:.8rem;margin-bottom:1rem}.spec-details{display:flex;flex-direction:column;gap:.75rem}.spec-field dt{font-size:.8rem;color:#8b949e;text-transform:capitalize;margin-bottom:.125rem}.spec-field dd{color:#e1e4e8;white-space:pre-wrap;font-size:.95rem}.spec-actions{display:flex;gap:1rem;align-items:center}.button-primary{padding:.75rem 1.5rem;background:#238636;color:#fff;border:none;border-radius:6px;font-size:1rem;cursor:pointer}.button-primary:hover:not(:disabled){background:#2ea043}.button-secondary{padding:.75rem 1.5rem;background:transparent;color:#8b949e;border:1px solid #30363d;border-radius:6px;font-size:1rem;cursor:pointer}.button-secondary:hover:not(:disabled){color:#e1e4e8;border-color:#8b949e}.button-secondary:disabled{opacity:.5;cursor:not-allowed}.spec-confirmed{color:#3fb950;font-weight:500}.conversation-list{max-width:800px;margin:0 auto;padding:2rem 1.5rem;width:100%}.conversation-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.conversation-list-header h2{font-size:1.5rem}.empty-state{text-align:center;padding:3rem;color:#8b949e}.conversation-items{display:flex;flex-direction:column;gap:.75rem}.conversation-card{display:block;width:100%;text-align:left;background:#161b22;border:1px solid #30363d;border-radius:8px;padding:1rem 1.25rem;cursor:pointer;color:#e1e4e8;transition:border-color .2s}.conversation-card:hover{border-color:#58a6ff}.conversation-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.conversation-type{font-weight:600;text-transform:capitalize;font-size:.95rem}.conversation-status{padding:.2rem .6rem;border-radius:12px;font-size:.75rem;font-weight:500}.status-active{background:#1f6feb22;color:#58a6ff}.status-spec_ready{background:#f0883e22;color:#f0883e}.status-confirmed{background:#3fb95022;color:#3fb950}.status-building{background:#a371f722;color:#a371f7}.status-deployed{background:#3fb95022;color:#3fb950}.conversation-preview{color:#8b949e;font-size:.85rem;line-height:1.4;margin-bottom:.5rem}.conversation-date{color:#484f58;font-size:.75rem}.build-status{margin-top:1.5rem;background:#161b22;border:1px solid #30363d;border-radius:8px;padding:1.5rem}.build-status h3{margin-bottom:1rem;font-size:1.1rem}.build-info{display:flex;flex-direction:column;gap:.75rem}.build-repo a{color:#58a6ff;text-decoration:none}.build-repo a:hover{text-decoration:underline}.build-version{margin-left:.75rem;padding:.15rem .5rem;background:#1f6feb22;color:#58a6ff;border-radius:8px;font-size:.75rem;font-weight:600}.build-error{color:#f85149;background:#f8514922;padding:.75rem;border-radius:6px;font-size:.9rem}.status-pending{background:#8b949e22;color:#8b949e}.status-completed{background:#3fb95022;color:#3fb950}.status-failed{background:#f8514922;color:#f85149}.scorecard{margin-top:.5rem}.scorecard h4{margin-bottom:.75rem;font-size:1rem;color:#8b949e}.scorecard-items{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.scorecard-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:#0d1117;border-radius:6px}.scorecard-label{color:#8b949e;font-size:.85rem}.scorecard-value{font-weight:600;font-size:.85rem}.scorecard-value.pass{color:#3fb950}.scorecard-value.fail{color:#f85149}.scorecard-value.clickable{cursor:pointer;text-decoration:underline}.vuln-details{margin-top:.75rem;padding:.75rem;background:#0d1117;border-radius:6px}.vuln-details h4{font-size:.9rem;color:#8b949e;margin-bottom:.5rem}.vuln-item{padding:.5rem .75rem;margin-bottom:.5rem;border-radius:4px;border-left:3px solid}.vuln-high{background:#f8514911;border-color:#f85149}.vuln-medium{background:#f0883e11;border-color:#f0883e}.vuln-low{background:#8b949e11;border-color:#8b949e}.vuln-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.vuln-severity{font-size:.7rem;font-weight:700;padding:.1rem .4rem;border-radius:4px}.severity-high{background:#f8514933;color:#f85149}.severity-medium{background:#f0883e33;color:#f0883e}.severity-low{background:#8b949e33;color:#8b949e}.vuln-file{font-family:monospace;font-size:.75rem;color:#8b949e}.vuln-issue{font-size:.85rem;color:#e1e4e8;line-height:1.4}.build-steps{display:flex;flex-direction:column;gap:.375rem;margin-bottom:1rem;padding:.75rem;background:#0d1117;border-radius:6px}.build-step{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.step-icon{width:1.25rem;text-align:center;font-size:.9rem}.step-completed .step-icon{color:#3fb950}.step-in_progress .step-icon{color:#58a6ff;animation:pulse 1.5s infinite}.step-in_progress .step-name{color:#58a6ff}.step-completed .step-name{color:#8b949e}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.status-awaiting_config{background:#f0883e22;color:#f0883e}.config-section{margin-top:1.5rem;background:#161b22;border:1px solid #30363d;border-radius:8px;padding:1.5rem}.config-section h3{margin-bottom:.5rem}.config-subtitle{color:#8b949e;font-size:.9rem;margin-bottom:1.25rem}.config-fields{display:flex;flex-direction:column;gap:.75rem}.config-field{display:flex;flex-direction:column;gap:.25rem}.config-field label{font-size:.8rem;color:#8b949e;font-family:monospace;display:flex;align-items:center;gap:.375rem}.secret-icon{font-size:.7rem}.config-field input{padding:.5rem .75rem;background:#0d1117;border:1px solid #30363d;border-radius:6px;color:#e1e4e8;font-size:.9rem;font-family:monospace;outline:none}.config-field textarea{padding:.5rem .75rem;background:#0d1117;border:1px solid #30363d;border-radius:6px;color:#e1e4e8;font-size:.9rem;font-family:monospace;outline:none;resize:vertical}.config-field input:focus,.config-field textarea:focus{border-color:#58a6ff}.config-field textarea:disabled{opacity:.6}.config-field input:disabled{opacity:.6}.config-actions{margin-top:1rem}.config-saved{color:#3fb950;font-weight:500}.deploy-section{margin-top:1.5rem}.deploy-status-section{margin-top:1.5rem;background:#161b22;border:1px solid #30363d;border-radius:8px;padding:1.5rem}.deploy-status-section h3{margin-bottom:1rem;font-size:1.1rem}.deploy-info{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.deploy-schedule{color:#8b949e;font-size:.85rem}.deploy-container{color:#8b949e;font-size:.85rem;font-family:monospace}.status-deploying{background:#a371f722;color:#a371f7}.status-deploy_failed{background:#f8514922;color:#f85149}.status-stopped{background:#8b949e22;color:#8b949e}.status-outdated{background:#f0883e22;color:#f0883e}.deploy-actions{display:flex;gap:.75rem}.button-danger{padding:.75rem 1.5rem;background:#da3633;color:#fff;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:background .2s}.button-danger:hover:not(:disabled){background:#f85149}.button-danger:disabled{opacity:.5;cursor:not-allowed}.files-section{margin-top:1.5rem;background:#161b22;border:1px solid #30363d;border-radius:8px;padding:1.5rem}.files-section h3{margin-bottom:1rem;font-size:1.1rem}.files-list{display:flex;flex-direction:column;gap:.5rem}.file-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:#0d1117;border-radius:6px}.file-info{display:flex;align-items:center;gap:1rem}.file-name{font-family:monospace;font-size:.9rem;color:#e1e4e8}.file-size{color:#8b949e;font-size:.8rem}.file-download{padding:.375rem .75rem;font-size:.8rem}
