*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}:root{--bg-primary:#0a0a0f;--bg-secondary:#111118;--bg-tertiary:#1a1a24;--border:#2a2a36;--text-primary:#e8e8ed;--text-secondary:#9090a0;--text-muted:#606070;--accent:#6366f1;--accent-hover:#818cf8;--success:#22c55e;--error:#ef4444;--warning:#f59e0b}body{background:var(--bg-primary);color:var(--text-primary);min-height:100vh;font-family:Segoe UI,system-ui,-apple-system,sans-serif}.hidden{display:none!important}#catalog-view{min-height:100vh}.hero{text-align:center;background:radial-gradient(60% 40% at 50% 0,#6366f114,#0000);padding:72px 24px 48px}.hero-inner{max-width:620px;margin:0 auto}.hero-logo{letter-spacing:-.03em;color:var(--text-primary);font-size:42px;font-weight:800}.hero-logo span{color:var(--accent)}.hero-tagline{color:var(--text-secondary);letter-spacing:.02em;text-transform:uppercase;margin-top:8px;font-size:16px;font-weight:500}.hero-description{color:var(--text-muted);margin-top:16px;font-size:15px;line-height:1.7}.hero-cta{background:var(--accent);color:#fff;border-radius:8px;margin-top:28px;padding:12px 32px;font-size:14px;font-weight:600;text-decoration:none;transition:background .15s,transform .1s;display:inline-block}.hero-cta:hover{background:var(--accent-hover);transform:translateY(-1px)}.about{padding:0 24px 56px}.about-inner{max-width:900px;margin:0 auto}.about-heading{color:var(--text-primary);text-align:center;letter-spacing:-.02em;margin-bottom:12px;font-size:26px;font-weight:700}.about-lead{text-align:center;color:var(--text-secondary);max-width:680px;margin:0 auto 40px;font-size:15px;line-height:1.75}.value-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:40px;display:grid}.value-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;padding:28px 24px}.value-card h3{color:var(--text-primary);margin-bottom:8px;font-size:15px;font-weight:600}.value-card p{color:var(--text-muted);font-size:13px;line-height:1.65}.about-who{background:var(--bg-secondary);border:1px solid var(--border);text-align:center;border-radius:10px;padding:28px 32px}.about-who h3{color:var(--text-primary);margin-bottom:10px;font-size:16px;font-weight:600}.about-who p{color:var(--text-secondary);max-width:640px;margin:0 auto;font-size:14px;line-height:1.7}.catalog{padding:0 24px 64px}.catalog-inner{max-width:1100px;margin:0 auto}.filter-bar{flex-wrap:wrap;gap:24px;margin-bottom:24px;display:flex}.filter-group{align-items:center;gap:10px;display:flex}.filter-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);white-space:nowrap;font-size:12px;font-weight:600}.filter-pills{flex-wrap:wrap;gap:6px;display:flex}.pill{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:20px;padding:5px 14px;font-size:12px;font-weight:500;transition:all .15s}.pill:hover{border-color:var(--text-muted);color:var(--text-primary)}.pill.active{background:var(--accent);border-color:var(--accent);color:#fff}.lab-count{color:var(--text-muted);margin-bottom:16px;font-size:13px}.lab-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;display:grid}.lab-card{background:var(--bg-secondary);border:1px solid var(--border);cursor:pointer;border-radius:10px;flex-direction:column;gap:12px;padding:24px;transition:border-color .2s,transform .15s,box-shadow .2s;display:flex}.lab-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.lab-card .card-badges{gap:8px;display:flex}.lab-card .card-title{color:var(--text-primary);font-size:16px;font-weight:600;line-height:1.4}.lab-card .card-description{color:var(--text-muted);flex:1;font-size:13px;line-height:1.6}.lab-card .card-footer{justify-content:flex-end;align-items:center;margin-top:4px;display:flex}.lab-card .launch-label{color:var(--accent);text-transform:uppercase;letter-spacing:.04em;opacity:0;font-size:12px;font-weight:600;transition:opacity .15s}.lab-card:hover .launch-label{opacity:1}.site-footer{text-align:center;border-top:1px solid var(--border);padding:40px 24px}.site-footer p{color:var(--text-muted);max-width:480px;margin:0 auto;font-size:13px;line-height:1.6}.site-footer .footer-contact{margin-top:12px}.site-footer a{color:var(--accent);text-decoration:none}.site-footer a:hover{text-decoration:underline}#runner-view{flex-direction:column;height:100vh;display:flex;overflow:hidden}#back-btn{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;width:30px;height:30px;font-size:16px;transition:border-color .15s,color .15s;display:flex}#back-btn:hover{border-color:var(--text-muted);color:var(--text-primary)}header{background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;height:48px;padding:0 20px;display:flex}.header-left{align-items:center;gap:12px;display:flex}header h1{color:var(--accent);letter-spacing:-.01em;font-size:15px;font-weight:700}.separator{color:var(--border);font-weight:300}#lab-title{color:var(--text-secondary);font-size:13px}#status{background:var(--bg-tertiary);color:var(--text-muted);border-radius:4px;padding:4px 10px;font-size:12px}#status.booting{color:var(--warning);background:#f59e0b1a}#status.running{color:var(--success);background:#22c55e1a}#status.error{color:var(--error);background:#ef44441a}main{flex:1;display:flex;overflow:hidden}#app-pane{flex-direction:column;flex:1;min-width:300px;display:flex;position:relative}#url-bar{background:var(--bg-tertiary);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:0;padding:4px 8px;display:flex}#url-bar .url-bar-prefix{color:var(--text-muted);-webkit-user-select:none;user-select:none;padding:0 2px 0 6px;font-family:Cascadia Code,Fira Code,monospace;font-size:13px}#url-input{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);border-radius:4px;outline:none;flex:1;padding:5px 8px;font-family:Cascadia Code,Fira Code,monospace;font-size:13px;transition:border-color .2s}#url-input:focus{border-color:var(--accent)}#url-go{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:4px;margin-left:4px;padding:5px 10px;font-size:12px;font-weight:600;transition:all .15s}#url-go:hover{background:var(--accent);color:#fff;border-color:var(--accent)}#app-frame{background:#fff;border:none;flex:1;width:100%}#app-loading{background:var(--bg-primary);z-index:10;flex-direction:column;justify-content:center;align-items:center;gap:16px;transition:opacity .3s;display:flex;position:absolute;inset:0}#app-loading.hidden{opacity:0;pointer-events:none}#loading-text{color:var(--text-muted);font-size:13px}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:28px;height:28px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}#divider{background:var(--border);cursor:col-resize;flex-shrink:0;width:1px}#divider:hover{background:var(--accent)}#side-panel{background:var(--bg-secondary);flex-direction:column;width:420px;min-width:320px;display:flex;overflow:hidden}.tabs{border-bottom:1px solid var(--border);flex-shrink:0;display:flex}.tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:10px 16px;font-size:13px;font-weight:500;transition:color .15s,border-color .15s}.tab:hover{color:var(--text-secondary)}.tab.active{color:var(--text-primary);border-bottom-color:var(--accent)}.tab-content{flex:1;display:none;overflow-y:auto}.tab-content.active{display:block}.brief-section{border-bottom:1px solid var(--border);padding:16px 20px}.brief-meta{gap:8px;margin-bottom:12px;display:flex}.badge{text-transform:uppercase;letter-spacing:.03em;border-radius:4px;padding:3px 10px;font-size:11px;font-weight:600}.badge.category{color:var(--accent-hover);background:#6366f126}.badge.difficulty{color:#4ade80;background:#22c55e1f}.badge.new-badge{color:#fbbf24;background:#f59e0b26;border:1px solid #f59e0b4d;animation:2s ease-in-out infinite new-pulse}@keyframes new-pulse{0%,to{opacity:1}50%{opacity:.7}}.description{color:var(--text-secondary);font-size:14px;line-height:1.6}.brief-section h3{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:12px;font-size:13px;font-weight:600}.brief-section ul{flex-direction:column;gap:8px;list-style:none;display:flex}.brief-section ul li{color:var(--text-secondary);padding-left:18px;font-size:13px;line-height:1.5;position:relative}.brief-section ul li:before{content:"→";color:var(--accent);position:absolute;left:0}.hint-toggle{background:var(--bg-tertiary);border:1px solid var(--border);width:100%;color:var(--text-muted);cursor:pointer;text-align:left;border-radius:6px;margin-bottom:6px;padding:10px 14px;font-size:13px;transition:color .15s,border-color .15s;display:block}.hint-toggle:hover{color:var(--text-secondary);border-color:var(--text-muted)}.hint-toggle.revealed{color:var(--text-secondary);background:var(--bg-primary);cursor:default}.flag-section{border-bottom:none}.flag-input-row{gap:8px;display:flex}#flag-input{background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);border-radius:6px;flex:1;padding:10px 12px;font-family:Cascadia Code,Fira Code,monospace;font-size:14px}#flag-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #6366f126}#flag-submit{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:6px;padding:10px 20px;font-size:13px;font-weight:600;transition:background .15s}#flag-submit:hover{background:var(--accent-hover)}#flag-feedback{min-height:20px;margin-top:10px;font-size:13px}#flag-feedback.success{color:var(--success)}#flag-feedback.error{color:var(--error)}#log-panel{padding:12px 16px;font-family:Cascadia Code,Fira Code,monospace;font-size:12px;line-height:1.7}.log-entry{color:var(--text-muted);word-break:break-all}.log-entry.info{color:var(--success)}.log-entry.warn{color:var(--warning)}.log-entry.error{color:var(--error)}#success-overlay{z-index:100;background:#000c;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.success-card{background:var(--bg-secondary);border:1px solid var(--border);text-align:center;border-radius:12px;max-width:500px;padding:40px}.success-card h2{color:var(--success);margin-bottom:12px;font-size:24px}.success-card p{color:var(--text-secondary);margin-bottom:8px;font-size:14px;line-height:1.6}.success-card .flag-display{color:var(--accent-hover);background:var(--bg-primary);word-break:break-all;border-radius:6px;margin:16px 0;padding:10px 16px;font-family:Cascadia Code,Fira Code,monospace;font-size:14px}.next-lab-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;margin-top:20px;padding:10px 28px;font-size:14px;font-weight:600;transition:background .15s}.next-lab-btn:hover{background:var(--accent-hover)}.feedback-widget{background:var(--bg-primary);border:1px solid var(--border);text-align:center;border-radius:8px;margin:20px 0 8px;padding:20px}.feedback-prompt{color:var(--text-secondary);margin-bottom:10px;font-size:13px}.star-rating{gap:4px;margin-bottom:12px;display:inline-flex}.star-rating .star{color:var(--border);cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:28px;line-height:1;transition:color .1s,transform .1s}.star-rating .star:hover,.star-rating .star.hovered{color:#fbbf24;transform:scale(1.15)}.star-rating .star.selected{color:#fbbf24}.feedback-comment{background:var(--bg-secondary);border:1px solid var(--border);width:100%;color:var(--text-primary);resize:vertical;border-radius:6px;margin-bottom:10px;padding:8px 12px;font-family:inherit;font-size:13px;display:block}.feedback-comment:focus{border-color:var(--accent);outline:none}.feedback-submit-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:8px 20px;font-size:13px;font-weight:600;transition:background .15s,opacity .15s}.feedback-submit-btn:hover:not(:disabled){background:var(--accent-hover)}.feedback-submit-btn:disabled{opacity:.5;cursor:not-allowed}.feedback-status{color:var(--error);min-height:16px;margin-top:8px;font-size:12px}.feedback-done{color:var(--success);padding:8px 0;font-size:13px}.card-rating{align-items:center;gap:6px;margin-top:-4px;display:flex}.star-display{font-size:14px;line-height:1}.star-display.filled{color:#fbbf24}.star-display.half{color:#fbbf24;opacity:.6}.star-display.empty{color:var(--border)}.rating-text{color:var(--text-muted);margin-left:2px;font-size:12px}
