* { margin: 0; padding: 0; box-sizing: border-box; } body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif; background: #f5f5f5; color: #333; } .hidden { display: none !important; } /* Login Page */ #login-page { display: flex; justify-content: center; align-items: center; min-height: 100vh; background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); } .login-container { background: white; padding: 3rem; border-radius: 10px; box-shadow: 0 10px 40px rgba(0,0,0,0.2); text-align: center; max-width: 400px; width: 100%; } .login-container h1 { margin-bottom: 0.5rem; color: #667eea; } .login-container p { color: #666; margin-bottom: 2rem; } .login-buttons { display: flex; flex-direction: column; gap: 1rem; } /* Main Page */ #main-page { min-height: 100vh; } header { background: white; padding: 1rem 2rem; box-shadow: 0 2px 4px rgba(0,0,0,0.1); display: flex; justify-content: space-between; align-items: center; } header h1 { color: #667eea; } .user-info { display: flex; align-items: center; gap: 1rem; } nav { background: white; padding: 0 2rem; border-bottom: 1px solid #e0e0e0; display: flex; gap: 1rem; } .nav-btn { padding: 1rem 1.5rem; background: none; border: none; border-bottom: 2px solid transparent; cursor: pointer; font-size: 1rem; color: #666; transition: all 0.2s; } .nav-btn:hover { color: #667eea; } .nav-btn.active { color: #667eea; border-bottom-color: #667eea; } main { max-width: 1200px; margin: 2rem auto; padding: 0 2rem; } .content-page { background: white; padding: 2rem; border-radius: 8px; box-shadow: 0 2px 4px rgba(0,0,0,0.1); } .content-page h2 { margin-bottom: 1.5rem; color: #333; } /* Buttons */ .btn { padding: 0.75rem 1.5rem; border: none; border-radius: 5px; cursor: pointer; font-size: 1rem; text-decoration: none; display: inline-block; transition: all 0.2s; } .btn-primary { background: #667eea; color: white; } .btn-primary:hover { background: #5568d3; } .btn-secondary { background: #6c757d; color: white; } .btn-secondary:hover { background: #5a6268; } .btn-google { background: #db4437; color: white; } .btn-google:hover { background: #c23321; } .btn-discord { background: #5865F2; color: white; } .btn-discord:hover { background: #4752C4; } /* Forms */ .form-group { margin-bottom: 1.5rem; } .form-group label { display: block; margin-bottom: 0.5rem; font-weight: 500; color: #333; } .form-group input, .form-group select { width: 100%; padding: 0.75rem; border: 1px solid #ddd; border-radius: 5px; font-size: 1rem; } .form-group input:focus, .form-group select:focus { outline: none; border-color: #667eea; } /* Jobs List */ #jobs-list { display: grid; gap: 1rem; } .job-card { background: #f8f9fa; padding: 1.5rem; border-radius: 8px; border-left: 4px solid #667eea; } .job-card h3 { margin-bottom: 0.5rem; color: #333; } .job-meta { display: flex; gap: 2rem; margin: 1rem 0; color: #666; font-size: 0.9rem; } .job-status { display: inline-block; padding: 0.25rem 0.75rem; border-radius: 20px; font-size: 0.85rem; font-weight: 500; } .job-status.pending { background: #ffc107; color: #000; } .job-status.running { background: #17a2b8; color: white; } .job-status.completed { background: #28a745; color: white; } .job-status.failed { background: #dc3545; color: white; } .job-status.cancelled { background: #6c757d; color: white; } .progress-bar { width: 100%; height: 8px; background: #e0e0e0; border-radius: 4px; overflow: hidden; margin: 1rem 0; } .progress-fill { height: 100%; background: #667eea; transition: width 0.3s; } .job-actions { margin-top: 1rem; display: flex; gap: 1rem; } /* Runners List */ #runners-list { display: grid; gap: 1rem; } .runner-card { background: #f8f9fa; padding: 1.5rem; border-radius: 8px; border-left: 4px solid #28a745; } .runner-card h3 { margin-bottom: 0.5rem; color: #333; } .runner-info { display: flex; gap: 2rem; margin-top: 1rem; color: #666; font-size: 0.9rem; } .runner-status { display: inline-block; padding: 0.25rem 0.75rem; border-radius: 20px; font-size: 0.85rem; font-weight: 500; } .runner-status.online { background: #28a745; color: white; } .runner-status.offline { background: #6c757d; color: white; } .runner-status.busy { background: #ffc107; color: #000; }