*{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}.site-nav{z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);background:#0a0a0fd9;position:sticky;top:0}.site-nav-inner{align-items:center;max-width:1100px;height:48px;margin:0 auto;padding:0 24px;display:flex}.site-nav-inner .nav-logo{flex:1}.nav-logo{letter-spacing:-.03em;color:var(--text-primary);font-size:18px;font-weight:800}.nav-logo span{color:var(--accent)}#auth-area{align-items:center;margin-left:auto;display:flex;position:relative}.auth-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:6px 18px;font-size:13px;font-weight:600;transition:background .15s}.auth-btn:hover{background:var(--accent-hover)}.user-pill{background:var(--bg-tertiary);border:1px solid var(--border);cursor:pointer;border-radius:20px;align-items:center;gap:8px;padding:4px 12px 4px 6px;transition:border-color .15s;display:flex}.user-pill:hover{border-color:var(--text-muted)}.user-avatar{font-size:20px;line-height:1}.user-handle{color:var(--text-primary);font-size:13px;font-weight:600}.user-dropdown{background:var(--bg-secondary);border:1px solid var(--border);z-index:60;border-radius:8px;min-width:160px;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden;box-shadow:0 8px 24px #0006}.dropdown-item{width:100%;color:var(--text-secondary);text-align:left;cursor:pointer;background:0 0;border:none;padding:10px 16px;font-size:13px;transition:background .1s,color .1s;display:block}.dropdown-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.auth-optional-hint{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-right:10px;font-size:10px;font-weight:600}.modal-overlay{z-index:200;background:#000000bf;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;width:100%;max-width:400px;padding:32px;position:relative}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:22px;line-height:1;transition:color .15s;position:absolute;top:12px;right:16px}.modal-close:hover{color:var(--text-primary)}.modal-tabs{border-bottom:1px solid var(--border);gap:0;margin-bottom:24px;display:flex}.modal-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:10px;font-size:14px;font-weight:600;transition:color .15s,border-color .15s}.modal-tab:hover{color:var(--text-secondary)}.modal-tab.active{color:var(--text-primary);border-bottom-color:var(--accent)}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);flex-direction:column;gap:6px;font-size:12px;font-weight:600;display:flex}.auth-input{background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);border-radius:6px;padding:10px 12px;font-family:inherit;font-size:14px}.auth-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #6366f126}.auth-hint{text-transform:none;letter-spacing:0;color:var(--text-muted);font-size:11px;font-weight:400}.auth-error{color:var(--error);min-height:18px;font-size:13px}.auth-submit{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:10px;font-size:14px;font-weight:600;transition:background .15s}.auth-submit:hover{background:var(--accent-hover)}.auth-optional{color:var(--text-muted);text-align:center;margin-bottom:8px;font-size:12px;line-height:1.5}.auth-perks{background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;margin-bottom:4px;padding:14px 16px}.auth-perks-title{color:var(--text-secondary);margin-bottom:8px;font-size:12px;font-weight:600}.auth-perks-list{flex-direction:column;gap:5px;margin-bottom:10px;list-style:none;display:flex}.auth-perks-list li{color:var(--text-muted);padding-left:18px;font-size:12px;line-height:1.4;position:relative}.auth-perks-list li:before{content:"+";color:var(--success);font-weight:700;position:absolute;left:4px}.auth-perks-note{color:var(--text-muted);font-size:11px;font-style:italic}.avatar-picker{flex-direction:column;gap:8px;display:flex}.avatar-grid{flex-wrap:wrap;gap:8px;display:flex}.avatar-option{background:var(--bg-primary);border:2px solid var(--border);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;width:42px;height:42px;font-size:22px;transition:border-color .15s,transform .1s;display:flex}.avatar-option:hover{border-color:var(--text-muted);transform:scale(1.08)}.avatar-option.selected{border-color:var(--accent);box-shadow:0 0 0 2px #6366f14d}#toast-container{z-index:300;pointer-events:none;flex-direction:column;gap:10px;display:flex;position:fixed;top:60px;right:20px}.toast{background:var(--bg-secondary);pointer-events:auto;border:1px solid #6366f166;border-radius:10px;align-items:center;gap:12px;padding:14px 20px;transition:transform .3s;display:flex;transform:translate(120%);box-shadow:0 8px 32px #0006}.toast.show{transform:translate(0)}.toast-icon{font-size:28px;line-height:1}.toast strong{color:var(--accent-hover);font-size:13px}.toast-desc{color:var(--text-secondary);font-size:12px}.leaderboard-empty{color:var(--text-muted);text-align:center;padding:32px 0;font-size:14px}.lb-table{border-collapse:collapse;width:100%;font-size:13px}.lb-table th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--border);padding:8px 12px;font-size:11px;font-weight:600}.lb-table td{color:var(--text-secondary);border-bottom:1px solid var(--border);padding:10px 12px}.lb-table tbody tr:hover{background:var(--bg-tertiary)}.lb-rank{width:40px;font-weight:700}.lb-user{color:var(--text-primary);font-weight:600}.lb-avatar{vertical-align:middle;margin-right:4px;font-size:18px}tr.rank-gold .lb-rank{color:#fbbf24}tr.rank-silver .lb-rank{color:silver}tr.rank-bronze .lb-rank{color:#cd7f32}tr.rank-gold .lb-user{color:#fbbf24}tr.rank-silver .lb-user{color:#d4d4d4}tr.rank-bronze .lb-user{color:#cd7f32}.profile-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;width:100%;max-width:700px;max-height:85vh;padding:32px;position:relative;overflow-y:auto}.profile-loading{text-align:center;color:var(--text-muted);padding:40px 0;font-size:14px}.profile-header{align-items:center;gap:16px;margin-bottom:24px;display:flex}.profile-avatar{font-size:48px;line-height:1}.profile-handle{color:var(--text-primary);font-size:24px;font-weight:700}.profile-meta{color:var(--text-muted);margin-top:4px;font-size:13px}.profile-stats{gap:16px;margin-bottom:28px;display:flex}.stat-box{background:var(--bg-primary);border:1px solid var(--border);text-align:center;border-radius:8px;flex:1;padding:16px}.stat-val{color:var(--text-primary);font-size:22px;font-weight:700}.stat-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-top:4px;font-size:11px;font-weight:600}.profile-section-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-top:4px;margin-bottom:12px;font-size:14px;font-weight:700}.ach-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;margin-bottom:28px;display:grid}.ach-item{background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;align-items:center;gap:10px;padding:10px 12px;transition:border-color .15s;display:flex}.ach-item.earned{border-color:#6366f14d}.ach-item.locked{opacity:.45}.ach-icon{flex-shrink:0;font-size:24px;line-height:1}.ach-title{color:var(--text-primary);font-size:12px;font-weight:600}.ach-item.locked .ach-title{color:var(--text-muted)}.ach-date{color:var(--text-muted);font-size:10px;display:block}.profile-fastest{color:var(--text-muted);background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;margin-bottom:24px;padding:10px 14px;font-size:13px}.profile-fastest strong{color:var(--accent-hover)}.path-progress-section{flex-direction:column;gap:10px;margin-bottom:28px;display:flex}.path-prog-row{align-items:center;gap:10px;display:flex}.path-prog-row.complete .path-prog-label,.path-prog-row.complete .path-prog-text{color:var(--success)}.path-prog-label{width:200px;color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;font-size:12px;font-weight:600;overflow:hidden}.path-prog-track{background:var(--bg-tertiary);border-radius:4px;flex:1;height:8px;overflow:hidden}.path-prog-fill{background:linear-gradient(90deg, var(--accent), var(--success));border-radius:4px;height:100%;transition:width .4s}.path-prog-text{color:var(--text-muted);text-align:right;flex-shrink:0;width:50px;font-size:12px;font-weight:600}.cat-breakdown{flex-direction:column;gap:8px;margin-bottom:28px;display:flex}.cat-bar-row{align-items:center;gap:10px;display:flex}.cat-bar-label{width:120px;color:var(--text-secondary);text-align:right;flex-shrink:0;font-size:12px;font-weight:600}.cat-bar-track{background:var(--bg-tertiary);border-radius:4px;flex:1;height:8px;overflow:hidden}.cat-bar-fill{background:linear-gradient(90deg, var(--accent), var(--success));border-radius:4px;height:100%;transition:width .4s}.cat-bar-text{color:var(--text-muted);flex-shrink:0;width:40px;font-size:12px;font-weight:600}.solve-history{border-collapse:collapse;width:100%;margin-bottom:8px;font-size:12px}.solve-history th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);padding:6px 8px;font-size:10px;font-weight:600}.solve-history td{color:var(--text-secondary);border-bottom:1px solid var(--border);padding:8px}.solve-history tbody tr:hover{background:var(--bg-tertiary)}.back-link{background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:8px;margin-right:20px;padding:6px 16px;font-size:13px;font-weight:600;transition:background .15s,border-color .15s,color .15s}.back-link:hover{background:var(--bg-secondary);border-color:var(--accent);color:var(--text-primary)}.site-nav-spacer{flex:1}.page-content{max-width:900px;margin:0 auto;padding:48px 24px 64px}.page-heading{color:var(--text-primary);letter-spacing:-.02em;margin-bottom:8px;font-size:28px;font-weight:700}.page-lead{color:var(--text-secondary);margin-bottom:32px;font-size:15px;line-height:1.6}#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;cursor:pointer;border:none;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 24px;font-size:15px;line-height:1.75}.leaderboard-cta{background:var(--success);color:#fff;cursor:pointer;border:none;border-radius:8px;margin:0 auto;padding:12px 32px;font-size:14px;font-weight:600;transition:background .15s,transform .1s;display:block}.leaderboard-cta:hover{background:#16a34a;transform:translateY(-1px)}#progress-tracker{margin-bottom:20px}.progress-text{color:var(--text-secondary);margin-bottom:6px;font-size:13px}.progress-bar-track{background:var(--bg-tertiary);border-radius:3px;height:6px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--accent), var(--success));border-radius:3px;height:100%;transition:width .4s}.badge.solved-badge{color:var(--success);background:#22c55e1f;border:1px solid #22c55e40}.lab-card.solved{opacity:.7}.lab-card.solved:hover{opacity:1}.badge.effort-badge{color:#eab308;background:#eab3081f;border:1px solid #eab3084d}.lab-card.high-effort{border-color:#eab3084d;box-shadow:0 0 0 1px #eab30814,0 0 20px #eab3080a}.lab-card.high-effort:hover{border-color:#eab30899;box-shadow:0 0 0 1px #eab30826,0 8px 24px #0000004d,0 0 24px #eab3080f}.paths-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px;display:grid}.path-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;padding:20px;transition:border-color .2s}.path-card:hover{border-color:#6366f14d}.path-card.complete{border-color:#22c55e4d}.path-title{color:var(--text-primary);margin-bottom:6px;font-size:15px;font-weight:600}.path-desc{color:var(--text-muted);margin-bottom:12px;font-size:13px;line-height:1.6}.path-progress{align-items:center;gap:10px;display:flex}.path-progress-text{color:var(--text-secondary);white-space:nowrap;min-width:36px;font-size:12px;font-weight:600}.path-progress-track{background:var(--bg-tertiary);border-radius:3px;flex:1;height:5px;overflow:hidden}.path-progress-fill{background:linear-gradient(90deg, var(--accent), var(--success));border-radius:3px;height:100%;transition:width .4s}.path-toggle{border:1px solid var(--border);width:100%;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;margin-top:12px;padding:6px;font-size:12px;font-weight:500;transition:color .15s,border-color .15s;display:block}.path-toggle:hover{color:var(--text-secondary);border-color:var(--text-muted)}.path-labs{flex-direction:column;gap:4px;margin-top:12px;display:flex}.path-labs.hidden{display:none}.path-lab{background:var(--bg-tertiary);cursor:pointer;border-radius:6px;align-items:center;gap:8px;padding:8px 10px;transition:background .15s;display:flex}.path-lab:hover{background:#6366f114}.path-lab-num{color:var(--text-muted);background:var(--bg-primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;font-size:11px;font-weight:700;display:flex}.path-lab.done .path-lab-num{color:var(--success);background:#22c55e26}.path-lab-check{color:var(--success);flex-shrink:0;width:14px;font-size:12px}.path-lab-title{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:12px;overflow:hidden}.path-lab.done .path-lab-title{color:var(--text-muted)}.path-lab .badge.difficulty{flex-shrink:0;padding:1px 6px;font-size:9px}.catalog{padding:0 24px 64px}.catalog-inner{max-width:1100px;margin:0 auto}.filter-bar{flex-direction:column;gap:14px;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{flex-wrap:wrap;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}
