.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg, #060609);padding:1rem}.auth-card{width:100%;max-width:420px;background:var(--surface, #0d0d14);border:1px solid var(--border, rgba(255, 255, 255, .07));border-radius:12px;padding:2rem}.auth-logo{width:56px;height:56px;display:block;margin:0 auto 16px}.auth-card h1{font-size:1.5rem;font-weight:700;font-family:var(--display, "Syne", sans-serif);color:var(--text, #e8eaf6);margin:0 0 .25rem}.auth-subtitle{color:var(--text-dim, #6b6b8a);font-size:.875rem;margin:0 0 1.5rem}.auth-error{background:#ff174414;border:1px solid rgba(255,23,68,.3);color:#ff8a80;padding:.75rem 1rem;border-radius:8px;font-size:.85rem;margin-bottom:1rem}.auth-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-group label{font-size:.8125rem;font-weight:500;color:var(--text-dim, #6b6b8a)}.form-group .optional{font-weight:400;color:var(--text-dim, #6b6b8a)}.form-group input{padding:.625rem .75rem;background:var(--bg, #060609);border:1px solid var(--border, rgba(255, 255, 255, .07));border-radius:8px;color:var(--text, #e8eaf6);font-size:.875rem;outline:none;transition:border-color .15s}.form-group input:focus{border-color:var(--cyan, #00e5ff)}.form-group input::placeholder{color:var(--text-dim, #6b6b8a)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;border-radius:8px;font-size:.875rem;font-weight:500;border:none;cursor:pointer;transition:background .15s,opacity .15s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--cyan, #00e5ff);color:#060609;font-weight:600;margin-top:.5rem}.btn-primary:hover:not(:disabled){background:#00c8e0}.auth-divider{display:flex;align-items:center;margin:1.25rem 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border, rgba(255, 255, 255, .07))}.auth-divider span{padding:0 .75rem;font-size:.75rem;color:var(--text-dim, #6b6b8a);text-transform:uppercase;letter-spacing:.05em}.oauth-buttons{display:flex;gap:.75rem}.btn-oauth{flex:1;background:var(--surface, #0d0d14);color:var(--text, #e8eaf6);border:1px solid var(--border, rgba(255, 255, 255, .07))}.btn-oauth:hover:not(:disabled){background:var(--surface2, #131320);border-color:#00e5ff33}.profile-page{min-height:100vh;background:var(--bg, #060609);padding:2rem}.profile-container{max-width:640px;margin:0 auto}.profile-header{display:flex;align-items:center;gap:1.25rem;margin-bottom:2rem}.profile-avatar{width:64px;height:64px;border-radius:50%;background:var(--cyan, #00e5ff);color:#060609;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:600;flex-shrink:0;overflow:hidden}.profile-avatar img{width:100%;height:100%;object-fit:cover}.profile-meta h1{font-size:1.5rem;font-weight:600;color:var(--text, #e8eaf6);margin:0 0 .25rem}.profile-meta p{font-size:.875rem;color:var(--text-dim, #6b6b8a);margin:0}.profile-card{background:var(--surface, #0d0d14);border:1px solid var(--border, rgba(255, 255, 255, .07));border-radius:12px;padding:1.5rem;margin-bottom:1rem}.profile-card h2{font-size:1rem;font-weight:600;color:var(--text, #e8eaf6);margin:0 0 1rem}.profile-row{display:flex;justify-content:space-between;padding:.625rem 0;border-bottom:1px solid var(--border, rgba(255, 255, 255, .07))}.profile-row:last-child{border-bottom:none}.profile-label{font-size:.8125rem;color:var(--text-dim, #6b6b8a)}.profile-value{font-size:.8125rem;color:var(--text, #e8eaf6);font-weight:500}.token-bar{height:8px;background:var(--bg, #060609);border-radius:4px;overflow:hidden;margin-top:.75rem}.token-bar-fill{height:100%;background:var(--cyan, #00e5ff);border-radius:4px;transition:width .3s ease}.profile-actions{display:flex;gap:.75rem;margin-top:1.5rem}.btn-outline{background:transparent;color:var(--text, #e8eaf6);border:1px solid var(--border, rgba(255, 255, 255, .07))}.btn-outline:hover:not(:disabled){background:var(--surface2, #131320);border-color:#00e5ff33}.btn-danger{background:#ef44441a;color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.btn-danger:hover:not(:disabled){background:#ef444433}.auth-footer{text-align:center;margin-top:1.5rem;font-size:.8125rem;color:var(--text-dim, #6b6b8a)}.auth-footer a{color:var(--cyan, #00e5ff);text-decoration:none;font-weight:500}.auth-footer a:hover{text-decoration:underline}.dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:dialog-fade-in .2s ease}@keyframes dialog-fade-in{0%{opacity:0}to{opacity:1}}.dialog-card{position:relative;width:100%;max-width:400px;background:var(--surface, #0d0d14);border:1px solid var(--border, rgba(255, 255, 255, .07));border-radius:16px;padding:2rem;text-align:center;animation:dialog-slide-in .25s ease}@keyframes dialog-slide-in{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.dialog-close{position:absolute;top:12px;right:12px;width:28px;height:28px;border:none;background:transparent;color:var(--text-dim, #6b6b8a);font-size:1.25rem;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.dialog-close:hover{background:var(--surface3, #1a1a2e);color:var(--text, #e8eaf6)}.dialog-icon{width:56px;height:56px;display:block;margin:0 auto 12px}.dialog-card h2{font-size:1.25rem;font-weight:600;color:var(--text, #e8eaf6);margin:0 0 .5rem}.dialog-subtitle{color:var(--text-dim, #6b6b8a);font-size:.875rem;margin:0 0 1.5rem;line-height:1.5}.dialog-subtitle strong{color:var(--cyan, #00e5ff)}.dialog-form{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.dialog-form input{width:100%;padding:.625rem .875rem;background:var(--bg, #060609);border:1px solid var(--border, rgba(255, 255, 255, .07));border-radius:8px;color:var(--text, #e8eaf6);font-size:.875rem;transition:border-color .15s;box-sizing:border-box}.dialog-form input:focus{outline:none;border-color:var(--cyan, #00e5ff)}.dialog-divider{display:flex;align-items:center;gap:1rem;margin:1rem 0;color:var(--text-dim, #6b6b8a);font-size:.75rem}.dialog-divider:before,.dialog-divider:after{content:"";flex:1;height:1px;background:var(--border, rgba(255, 255, 255, .07))}.dialog-footer{margin-top:1rem;font-size:.8125rem;color:var(--text-dim, #6b6b8a)}.dialog-footer a{color:var(--cyan, #00e5ff);text-decoration:none;font-weight:500}.dialog-footer a:hover{text-decoration:underline}.pricing-page{min-height:100vh;background:var(--bg);color:var(--text);display:flex;flex-direction:column;align-items:center;padding:4rem 1.5rem 3rem}.pricing-container{max-width:1200px;width:100%}.pricing-header{text-align:center;margin-bottom:3rem}.pricing-header h1{font-size:2.5rem;font-weight:700;margin-bottom:.75rem;background:linear-gradient(135deg,var(--text),var(--cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.pricing-header p{color:var(--text-dim);font-size:1.1rem;margin-bottom:1.5rem}.billing-toggle{display:inline-flex;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:3px;gap:2px}.toggle-btn{background:transparent;border:none;color:var(--text-dim);padding:.5rem 1.25rem;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .2s}.toggle-btn.active{background:#00e5ff1a;color:var(--cyan)}.save-badge{font-size:.7rem;background:var(--cyan);color:var(--bg);padding:2px 6px;border-radius:4px;margin-left:4px;font-weight:600}.pricing-error{background:#ff32321f;border:1px solid rgba(255,50,50,.3);color:#ff6b6b;padding:.75rem 1rem;border-radius:8px;text-align:center;margin-bottom:2rem;font-size:.9rem}.pricing-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-bottom:2.5rem}.pricing-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:2rem 1.5rem;display:flex;flex-direction:column;position:relative;transition:border-color .25s,transform .25s}.pricing-card:hover{border-color:#ffffff26;transform:translateY(-2px)}.pricing-card.popular{border-color:var(--cyan);box-shadow:0 0 30px #00e5ff14}.pricing-card.current{border-color:#00e5ff66}.popular-badge,.current-badge{position:absolute;top:-10px;right:16px;font-size:.7rem;font-weight:600;padding:3px 10px;border-radius:6px}.popular-badge{background:var(--cyan);color:var(--bg)}.current-badge{background:#00e5ff26;color:var(--cyan);border:1px solid rgba(0,229,255,.3)}.plan-tier{font-size:.75rem;font-weight:700;letter-spacing:1.5px;color:var(--text-dim);margin-bottom:1rem}.plan-price{margin-bottom:.5rem}.price-amount{font-size:2.75rem;font-weight:800;letter-spacing:-1px}.price-period{font-size:.9rem;color:var(--text-dim);margin-left:2px}.plan-desc{color:var(--text-dim);font-size:.85rem;margin-bottom:1.25rem;line-height:1.4;min-height:2.8em}.plan-points{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:1.25rem}.points-label{color:var(--text-dim);font-size:.8rem}.points-value{font-weight:700;font-size:1rem}.points-value.unlimited{color:var(--cyan)}.plan-features{list-style:none;padding:0;margin:0 0 1.5rem;flex:1}.plan-features li{position:relative;padding-left:1.25rem;font-size:.85rem;color:var(--text-dim);margin-bottom:.6rem;line-height:1.4}.plan-features li:before{content:"✓";position:absolute;left:0;color:var(--cyan);font-weight:700;font-size:.8rem}.trial-note{font-size:.75rem;color:var(--text-dim);text-align:center;margin-bottom:.75rem}.plan-btn{width:100%;padding:.75rem;border-radius:10px;border:1px solid var(--border);background:transparent;color:var(--text);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.plan-btn:hover:not(:disabled){border-color:var(--cyan);color:var(--cyan)}.plan-btn.primary{background:var(--cyan);color:var(--bg);border-color:var(--cyan)}.plan-btn.primary:hover:not(:disabled){filter:brightness(1.1);color:var(--bg)}.plan-btn.current{opacity:.5;cursor:default}.plan-btn:disabled{opacity:.4;cursor:not-allowed}.cancel-section{text-align:center;margin-bottom:2rem}.btn-cancel-link{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:.85rem;text-decoration:underline}.btn-cancel-link:hover{color:#ff6b6b}.cancel-confirm{background:var(--surface);border:1px solid rgba(255,50,50,.3);border-radius:12px;padding:1.25rem;display:inline-block}.cancel-confirm p{margin-bottom:1rem;font-size:.9rem;color:var(--text-dim)}.cancel-actions{display:flex;gap:.75rem;justify-content:center}.btn-danger{background:#ff323226;border:1px solid rgba(255,50,50,.4);color:#ff6b6b;padding:.5rem 1.25rem;border-radius:8px;cursor:pointer;font-weight:600;font-size:.85rem;transition:all .2s}.btn-danger:hover:not(:disabled){background:#ff323240}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text);padding:.5rem 1.25rem;border-radius:8px;cursor:pointer;font-size:.85rem;transition:all .2s}.btn-outline:hover{border-color:#fff3}.pricing-footer{text-align:center;color:var(--text-dim);font-size:.8rem;margin-bottom:1.5rem}.pricing-footer a{color:var(--cyan);text-decoration:none}.pricing-footer a:hover{text-decoration:underline}.pricing-actions{text-align:center}@media(max-width:1024px){.pricing-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.pricing-page{padding:2rem 1rem}.pricing-header h1{font-size:1.75rem}.pricing-grid{grid-template-columns:1fr;gap:1rem}.price-amount{font-size:2rem}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #060609;--surface: #0d0d14;--surface2: #131320;--surface3: #1a1a2e;--border: rgba(255, 255, 255, .07);--border2: rgba(0, 229, 255, .15);--cyan: #00e5ff;--cyan-dim: rgba(0, 229, 255, .12);--cyan-mid: rgba(0, 229, 255, .3);--amber: #ffb300;--green: #00e676;--red: #ff1744;--purple: #aa00ff;--text: #e8eaf6;--text-dim: #6b6b8a;--text-mid: #9898b8;--mono: "Space Mono", monospace;--display: "Syne", sans-serif}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--display);min-height:100vh;overflow-x:hidden}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:var(--surface)}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:40px 40px;pointer-events:none;z-index:0;opacity:.4}@keyframes pulse-cyan{0%,to{opacity:1}50%{opacity:.4}}@keyframes scan-line{0%{transform:translateY(-100%)}to{transform:translateY(100vh)}}@keyframes slide-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes progress-stripe{0%{background-position:0 0}to{background-position:40px 0}}#root{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column}.scan-overlay{position:fixed;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--cyan),transparent);opacity:.3;animation:scan-line 8s linear infinite;pointer-events:none;z-index:999}.header{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;border-bottom:1px solid var(--border);background:#060609e6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:sticky;top:0;z-index:100}.logo{display:flex;align-items:center;gap:12px}.logo-icon{width:36px;height:36px;flex-shrink:0}.logo-text{font-family:var(--display);font-weight:800;font-size:20px;letter-spacing:-.5px;background:linear-gradient(135deg,#fff 0%,var(--cyan) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.logo-sub{font-family:var(--mono);font-size:10px;color:var(--text-dim);letter-spacing:2px;text-transform:uppercase}.header-status{display:flex;align-items:center;gap:20px}.header-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent, #6366f1);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;text-decoration:none;overflow:hidden;flex-shrink:0;transition:opacity .15s}.header-avatar:hover{opacity:.85}.header-avatar img{width:100%;height:100%;object-fit:cover}.header-points{font-family:var(--mono);font-size:12px;color:var(--cyan, #22d3ee);display:flex;align-items:center;gap:4px;padding:3px 10px;background:#22d3ee14;border:1px solid rgba(34,211,238,.2);border-radius:12px;white-space:nowrap}.points-badge{display:flex;align-items:center;gap:6px;padding:10px 24px;border-bottom:1px solid var(--border);font-family:var(--mono);font-size:12px}.points-icon{color:var(--cyan, #22d3ee);font-size:14px}.points-value{color:var(--cyan, #22d3ee);font-weight:600}.points-label{color:var(--text-dim)}.status-pill{display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;border:1px solid;font-family:var(--mono);font-size:11px}.status-pill.online{border-color:#00e67666;background:#00e6760f;color:var(--green)}.status-pill.offline{border-color:#ff174466;background:#ff17440f;color:var(--red)}.status-dot{width:6px;height:6px;border-radius:50%;background:currentColor;animation:pulse-cyan 2s infinite}.main{display:grid;grid-template-columns:380px 1fr;grid-template-rows:1fr;min-height:calc(100vh - 65px);gap:0;transition:grid-template-columns .3s cubic-bezier(.4,0,.2,1)}.main.collapsed{grid-template-columns:0px 1fr}.left-panel{border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;background:var(--surface);transition:opacity .2s ease,visibility .2s ease;min-width:0}.main.collapsed .left-panel{opacity:0;visibility:hidden;pointer-events:none}.collapse-toggle{position:fixed;top:72px;left:380px;z-index:100;width:24px;height:48px;background:var(--surface2);border:1px solid var(--border);border-left:none;border-radius:0 8px 8px 0;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-dim);font-size:12px;transition:all .3s cubic-bezier(.4,0,.2,1)}.collapse-toggle:hover{background:var(--surface3);color:var(--cyan);border-color:var(--cyan)}.main.collapsed .collapse-toggle,.main.collapsed~.collapse-toggle{left:0}.collapse-toggle.is-collapsed{left:0}.right-panel{display:flex;flex-direction:column;overflow:hidden}.section{border-bottom:1px solid var(--border);padding:20px 24px}.section-label{font-family:var(--mono);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--text-dim);margin-bottom:16px;display:flex;align-items:center;gap:8px}.section-label:before{content:"";width:3px;height:3px;background:var(--cyan);border-radius:50%;box-shadow:0 0 6px var(--cyan)}.field{margin-bottom:14px}.field-label{font-family:var(--mono);font-size:11px;color:var(--text-mid);margin-bottom:6px;display:block}.field-input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:9px 12px;font-family:var(--mono);font-size:12px;color:var(--text);outline:none;transition:border-color .2s,box-shadow .2s}.field-input:focus{border-color:var(--cyan-mid);box-shadow:0 0 0 3px var(--cyan-dim)}.field-input::placeholder{color:var(--text-dim)}.field-select{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:9px 12px;font-family:var(--mono);font-size:12px;color:var(--text);outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236b6b8a'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.field-select:focus{border-color:var(--cyan-mid);box-shadow:0 0 0 3px var(--cyan-dim)}.chip-row{display:flex;gap:8px;flex-wrap:wrap}.chip{padding:5px 12px;border-radius:4px;border:1px solid var(--border);font-family:var(--mono);font-size:11px;cursor:pointer;color:var(--text-dim);background:var(--surface2);transition:all .15s;-webkit-user-select:none;user-select:none}.chip.active{border-color:var(--cyan);color:var(--cyan);background:var(--cyan-dim);box-shadow:0 0 8px var(--cyan-dim)}.slider-row{display:flex;align-items:center;gap:10px}.slider{flex:1;-webkit-appearance:none;height:2px;background:var(--surface3);border-radius:2px;outline:none}.slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--cyan);cursor:pointer;box-shadow:0 0 8px var(--cyan)}.slider-val{font-family:var(--mono);font-size:12px;color:var(--cyan);min-width:36px;text-align:right}.btn-submit{width:100%;padding:13px;background:transparent;border:1px solid var(--cyan);border-radius:6px;color:var(--cyan);font-family:var(--display);font-weight:700;font-size:14px;letter-spacing:1px;cursor:pointer;transition:all .2s;position:relative;overflow:hidden;text-transform:uppercase}.btn-submit:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--cyan-dim);opacity:0;transition:opacity .2s}.btn-submit:hover:before{opacity:1}.btn-submit:hover{box-shadow:0 0 20px var(--cyan-dim),0 0 40px #00e5ff0d}.btn-submit:disabled{opacity:.4;cursor:not-allowed}.btn-submit.running{border-color:var(--amber);color:var(--amber)}.btn-submit.running:before{background:#ffb30014;opacity:1}.job-list{display:flex;flex-direction:column;gap:6px;padding:16px}.job-item{padding:10px 14px;border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .15s;background:var(--surface2);display:flex;align-items:center;gap:10px;animation:slide-in .3s ease}.job-item:hover{border-color:var(--border2);background:var(--surface3)}.job-item.active{border-color:var(--cyan-mid);background:var(--cyan-dim)}.job-id{font-family:var(--mono);font-size:11px;color:var(--text-dim);flex-shrink:0}.job-name{font-size:13px;font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.job-status-badge{padding:2px 7px;border-radius:3px;font-family:var(--mono);font-size:10px;flex-shrink:0}.badge-pending{background:#6b6b8a4d;color:var(--text-dim)}.badge-running{background:#ffb30026;color:var(--amber)}.badge-done{background:#00e67626;color:var(--green)}.badge-failed{background:#ff174426;color:var(--red)}.job-delete-btn{flex-shrink:0;width:20px;height:20px;border:none;border-radius:3px;background:transparent;color:var(--text-dim);font-size:16px;line-height:1;cursor:pointer;opacity:0;transition:all .15s;display:flex;align-items:center;justify-content:center;padding:0}.job-item:hover .job-delete-btn{opacity:.6}.job-delete-btn:hover{opacity:1!important;background:#ff174433;color:var(--red)}.confirm-cancel-btn,.confirm-delete-btn{flex:1;padding:10px 0;border:1px solid var(--border);border-radius:6px;font-family:var(--mono);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.confirm-cancel-btn{background:var(--surface3);color:var(--text)}.confirm-cancel-btn:hover{border-color:var(--cyan);color:var(--cyan)}.confirm-delete-btn{background:#ff174426;border-color:#ff174466;color:var(--red)}.confirm-delete-btn:hover{background:#ff17444d;border-color:var(--red)}.tab-bar{display:flex;border-bottom:1px solid var(--border);padding:0 24px;background:var(--surface);flex-shrink:0}.tab{padding:14px 16px;font-family:var(--mono);font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--text-dim);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;margin-bottom:-1px}.tab:hover{color:var(--text-mid)}.tab.active{color:var(--cyan);border-bottom-color:var(--cyan)}.tab-count{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:var(--cyan-dim);border:1px solid var(--border2);font-size:9px;margin-left:5px;color:var(--cyan)}.overview{flex:1;overflow-y:auto;padding:24px}.overview-empty{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;opacity:.5}.empty-icon{width:64px;height:64px;border:1px solid var(--border2);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:28px}.empty-text{font-family:var(--mono);font-size:12px;color:var(--text-dim);text-align:center}.job-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;animation:fade-in .3s ease}.job-title{font-size:22px;font-weight:800;letter-spacing:-.5px;margin-bottom:4px}.job-meta{font-family:var(--mono);font-size:11px;color:var(--text-dim)}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}.stat-card{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:14px 16px;animation:fade-in .3s ease}.stat-label{font-family:var(--mono);font-size:10px;letter-spacing:1px;color:var(--text-dim);text-transform:uppercase;margin-bottom:6px}.stat-value{font-size:24px;font-weight:800;letter-spacing:-1px;color:var(--cyan)}.stat-value.amber{color:var(--amber)}.stat-value.green{color:var(--green)}.stat-value.red{color:var(--red)}.progress-section{margin-bottom:24px}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.progress-label{font-family:var(--mono);font-size:11px;color:var(--text-mid)}.progress-pct{font-family:var(--mono);font-size:13px;color:var(--cyan);font-weight:700}.progress-track{height:4px;background:var(--surface3);border-radius:2px;overflow:hidden}.progress-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--cyan),#00b8d4);transition:width .5s cubic-bezier(.4,0,.2,1);background-size:40px 100%;animation:progress-stripe .8s linear infinite}.progress-fill.done{background:linear-gradient(90deg,var(--green),#00c853);animation:none}.progress-fill.failed{background:var(--red);animation:none}.screens-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-bottom:24px}.screen-card{position:relative;background:var(--surface2);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:all .2s;animation:slide-in .3s ease}.screen-card:hover{border-color:var(--border2);transform:translateY(-2px);box-shadow:0 8px 24px #0006}.screen-card.done{border-color:#00e6764d}.screen-card.running{border-color:#ffb3004d}.screen-preview{height:160px;background:var(--surface3);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.screen-preview img{width:100%;height:100%;object-fit:cover}.screen-preview-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-dim)}.screen-preview-icon{font-size:32px}.screen-preview-text{font-family:var(--mono);font-size:10px}.screen-iter-badge{position:absolute;top:8px;right:8px;padding:2px 8px;background:#000000b3;border:1px solid var(--border);border-radius:3px;font-family:var(--mono);font-size:10px;color:var(--text-dim)}.score-badge{position:absolute;bottom:8px;left:8px;padding:3px 10px;border-radius:4px;font-family:var(--mono);font-size:12px;font-weight:700}.score-badge.high{background:#00e67633;color:var(--green);border:1px solid rgba(0,230,118,.4)}.score-badge.mid{background:#ffb30033;color:var(--amber);border:1px solid rgba(255,179,0,.4)}.score-badge.low{background:#ff174433;color:var(--red);border:1px solid rgba(255,23,68,.4)}.screen-info{padding:12px}.screen-name{font-weight:700;font-size:14px;margin-bottom:4px}.screen-tags{display:flex;gap:6px;flex-wrap:wrap}.tag{padding:2px 7px;border-radius:3px;font-family:var(--mono);font-size:10px;background:var(--surface3);color:var(--text-dim);border:1px solid var(--border)}.spinner{width:14px;height:14px;border:2px solid rgba(255,179,0,.2);border-top-color:var(--amber);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}.spinner.cyan{border-color:var(--cyan-dim);border-top-color:var(--cyan)}.log-terminal{flex:1;overflow-y:auto;padding:16px 20px;background:#02020a;font-family:var(--mono);font-size:12px;line-height:1.8}.log-line{display:flex;gap:12px;animation:slide-in .2s ease}.log-ts{color:var(--text-dim);flex-shrink:0;font-size:11px}.log-svc{flex-shrink:0;width:90px;font-size:10px;letter-spacing:.5px}.log-svc.gateway{color:#7c4dff}.log-svc.orchestrator{color:#00e5ff}.log-svc.figma-parser{color:#ff6d00}.log-svc.codegen{color:#a0f}.log-svc.sandbox{color:#00b0ff}.log-svc.differ{color:#76ff03}.log-svc.notifier{color:#ff4081}.log-msg{flex:1}.log-msg.info{color:var(--text-mid)}.log-msg.warn{color:var(--amber)}.log-msg.error{color:var(--red)}.log-msg.done{color:var(--green)}.cursor{display:inline-block;width:8px;height:14px;background:var(--cyan);vertical-align:text-bottom;animation:blink 1s step-end infinite;margin-left:2px}.diff-viewer{flex:1;overflow-y:auto;padding:24px}.diff-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.diff-title{font-size:16px;font-weight:700}.diff-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:16px}.diff-pane{border:1px solid var(--border);border-radius:8px;overflow:hidden}.diff-pane-label{padding:8px 12px;background:var(--surface2);border-bottom:1px solid var(--border);font-family:var(--mono);font-size:11px;display:flex;align-items:center;gap:8px}.diff-pane-body{height:280px;background:var(--surface3);display:flex;align-items:center;justify-content:center;overflow:hidden}.diff-pane-body img{width:100%;height:100%;object-fit:contain}.diff-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-dim);font-family:var(--mono);font-size:11px}.code-viewer{flex:1;display:flex;flex-direction:column;min-height:0;padding:20px 24px;overflow:hidden}.code-toolbar{display:flex;gap:8px;margin-bottom:16px;flex-shrink:0;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.code-toolbar::-webkit-scrollbar{display:none}.code-tab{padding:5px 14px;border-radius:4px;border:1px solid var(--border);font-family:var(--mono);font-size:11px;cursor:pointer;color:var(--text-dim);background:var(--surface2);transition:all .15s;white-space:nowrap;flex-shrink:0}.code-tab.active{background:var(--cyan-dim);border-color:var(--cyan);color:var(--cyan)}.code-split{display:flex;flex:1;min-height:0;overflow:hidden;gap:0}.split-drag-handle{flex:0 0 8px;cursor:col-resize;display:flex;align-items:center;justify-content:center;background:var(--surface);transition:background .15s;z-index:5;position:relative}.split-drag-handle:hover,.split-drag-handle:active{background:var(--surface3)}.split-drag-handle:hover .split-drag-dots,.split-drag-handle:active .split-drag-dots{background:var(--cyan);box-shadow:0 -6px 0 var(--cyan),0 6px 0 var(--cyan)}.split-drag-dots{width:3px;height:3px;border-radius:50%;background:var(--text-dim);box-shadow:0 -6px 0 var(--text-dim),0 6px 0 var(--text-dim);transition:all .15s}.code-block{background:#02020a;border:1px solid var(--border);border-radius:8px;padding:20px;font-family:var(--mono);font-size:12px;line-height:1.8;overflow:auto;color:#a8b5e8;white-space:pre;flex:1;min-height:0;min-width:0;position:relative}.code-preview-pane{flex:1;min-height:0;min-width:0;border-left:1px solid var(--border);overflow:hidden;background:#fff;border-radius:0 0 8px;position:relative}.code-editor-pane{flex:1;min-height:0;min-width:0;overflow:hidden;background:#02020a;border:1px solid var(--border);border-radius:8px;position:relative}.code-editor-pane .monaco-editor,.code-editor-pane .overflow-guard{border-radius:8px}.code-editor-loading{display:flex;align-items:center;justify-content:center;height:100%;font-family:var(--mono);font-size:12px;color:var(--text-dim);opacity:.5}.code-copy{float:right;padding:3px 10px;background:var(--surface3);border:1px solid var(--border);border-radius:4px;font-family:var(--mono);font-size:10px;cursor:pointer;color:var(--text-dim);transition:all .15s}.code-copy:hover{border-color:var(--cyan);color:var(--cyan)}.skeleton{background:linear-gradient(90deg,var(--surface2) 25%,var(--surface3) 50%,var(--surface2) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px}.toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:10px;z-index:999}.toast{padding:12px 16px;border-radius:8px;border:1px solid;font-family:var(--mono);font-size:12px;min-width:280px;max-width:360px;animation:slide-in .3s ease;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.toast.success{background:#00e6761a;border-color:#00e67666;color:var(--green)}.toast.error{background:#ff17441a;border-color:#ff174466;color:var(--red)}.toast.info{background:#00e5ff1a;border-color:#00e5ff66;color:var(--cyan)}@media(max-width:900px){.main{grid-template-columns:1fr}.left-panel{border-right:none;border-bottom:1px solid var(--border);max-height:50vh}.stats-row{grid-template-columns:repeat(2,1fr)}.diff-grid{grid-template-columns:1fr}}
