.topic-card--skeleton{pointer-events:none;cursor:default}.topic-card--skeleton:hover,.topic-card--skeleton:active{transform:none;border-color:#3d4f66;border-top-color:#526480;border-bottom-color:#283548;box-shadow:0 0 0 1px #0f172aa6,inset 0 1px #64748b33,inset 0 -2px 6px #02061780,0 2px #080e1ae6,0 6px 14px #0006,0 14px 28px #0000004d}.topic-card--skeleton .topic-card-icon,.topic-card--skeleton .topic-card-arrow{color:transparent}.topic-card--skeleton .ws-skel-icon-block{display:block;width:24px;height:24px;border-radius:6px}.topic-card--skeleton .ws-skel-arrow-block{display:block;width:22px;height:22px;border-radius:6px}.topic-card--skeleton .ws-skel-action-ring{display:block;width:48px;height:48px;border-radius:50%;flex-shrink:0}#subjects-view .topic-card--skeleton .topic-card-body{gap:12px}#projects-view .topic-card--skeleton{min-height:72px}#projects-view .topic-card--skeleton .topic-card-body{gap:12px}#projects-view .topic-card--skeleton .topic-card-action--skeleton{width:76px;height:48px;display:flex;align-items:center;justify-content:flex-end}#projects-view .topic-card--skeleton .ws-skel-action-pill{display:block;width:76px;height:32px;border-radius:10px}:root{--bg-base: #07101e;--bg-panel: #0c1627;--bg-card: #0f1d33;--bg-input: #152340;--bg-elevated: #1a2d4a;--bg-editor: #111827;--bg-sidebar: #0a1220;--bg-tabbar: #0d1625;--bg-output: #090f1a;--border: #1a2e4a;--border-2: #233d60;--border-teal: rgba(56,189,248,.28);--border-blue: rgba(147,197,253,.25);--teal: #38bdf8;--teal-dim: rgba(56,189,248,.08);--teal-mid: rgba(56,189,248,.15);--teal-high: rgba(56,189,248,.28);--blue: #93c5fd;--blue-dim: rgba(147,197,253,.08);--blue-mid: rgba(147,197,253,.15);--green: #34d399;--green-dim: rgba(52,211,153,.08);--green-mid: rgba(52,211,153,.16);--purple: #c4b5fd;--score-gold: #f5c542;--score-gold-dim: rgba(245, 197, 66, .18);--score-gold-mid: rgba(245, 197, 66, .52);--amber: #fbbf24;--amber-dim: rgba(251,191,36,.08);--red: #f87171;--text-1: #edf2fb;--text-2: #b8cfe8;--text-3: #6a8aaa;--text-code: #a5c8ff;--font: "Inter", system-ui, -apple-system, sans-serif;--mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--fw-light: 300;--fw-regular: 400;--fw-medium: 500;--fw-semibold: 600;--fw-bold: 700;--fw-extrabold: 800;--header-h: 60px;--left-col-w: calc(35vw - 36px) ;--explorer-w: max-content;--output-h: 250px;--r: 18px;--r-sm: 10px;--r-xs: 6px;--task-col-toggle-right: 22px ;--task-col-toggle-size: 32px;--task-pill-toggle-gap: 4px;--task-meta-pad-r: calc(var(--task-col-toggle-right) + var(--task-col-toggle-size) + var(--task-pill-toggle-gap));--approach-accent-bg: radial-gradient(ellipse 130% 90% at 50% 0%, rgba(56, 189, 248, .16) 0%, transparent 62%), linear-gradient(180deg, #152a45 0%, #102238 52%, #0b1729 100%);--approach-accent-glow: inset 0 0 48px rgba(56, 189, 248, .06);--task-panel-bg: #0f1e38}.fw-light{font-weight:var(--fw-light)}.fw-regular{font-weight:var(--fw-regular)}.fw-medium{font-weight:var(--fw-medium)}.fw-semibold{font-weight:var(--fw-semibold)}.fw-bold{font-weight:var(--fw-bold)}.fw-extrabold{font-weight:var(--fw-extrabold)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}html:has(body.is-workspace){overflow:hidden}body.is-workspace{overflow:hidden;font-family:var(--font);background:var(--bg-base);color:var(--text-1);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text-3)}code,pre{font-family:var(--mono)}#app{display:flex;flex-direction:column;height:100%;overflow:hidden;position:relative}.app-header{position:fixed;top:0;left:0;right:0;height:var(--header-h);flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:0 18px 0 20px;background:var(--bg-panel);border-bottom:1px solid var(--border);gap:16px;z-index:100}.hdr-left,.hdr-right{display:flex;align-items:center;gap:12px}.hdr-left{min-width:0;flex:1}.app-logo-img{height:40px;width:auto;display:block;flex-shrink:0;cursor:pointer}.app-logo-img:focus-visible{outline:2px solid var(--teal);outline-offset:3px;border-radius:4px}.hdr-divider{width:1px;height:32px;background:var(--border-2);flex-shrink:0}.hdr-breadcrumb{display:flex;align-items:center;gap:6px;min-width:0;font-size:16px;line-height:1.2;color:var(--text-2);letter-spacing:.1px}.hdr-breadcrumb-static,.hdr-breadcrumb-item,.hdr-breadcrumb-sep,.hdr-breadcrumb-link,.hdr-breadcrumb-current{color:inherit}.hdr-breadcrumb-static,.hdr-breadcrumb-item,.hdr-breadcrumb-sep,.hdr-breadcrumb-link{font-weight:var(--fw-regular);font-size:12px;opacity:.65}.hdr-breadcrumb-static,.hdr-breadcrumb-item{flex-shrink:0;white-space:nowrap}.hdr-breadcrumb-sep{flex-shrink:0}.hdr-breadcrumb-link{cursor:pointer;flex-shrink:1;min-width:0;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hdr-breadcrumb-link:hover{text-decoration:underline}.hdr-breadcrumb-prefix{display:inline-flex;align-items:center;gap:6px;flex-shrink:0;max-width:55%;padding:0;margin:0;border:none;background:transparent;color:var(--text-2);opacity:.75;font-size:16px;line-height:1.2;cursor:pointer;transition:color .16s ease,opacity .16s ease}.hdr-breadcrumb-prefix:focus-visible{outline:2px solid var(--teal);outline-offset:2px;border-radius:4px}.hdr-breadcrumb-back-icon{display:block;width:1em;height:1em;flex-shrink:0}.hdr-breadcrumb-prefix .hdr-breadcrumb-muted{font-weight:var(--fw-medium);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hdr-breadcrumb-current{flex:1;min-width:0;font-size:16px;line-height:1.2;color:var(--text-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hdr-breadcrumb-current .hdr-breadcrumb-project-name{font-weight:var(--fw-semibold);opacity:1}.hdr-progress-wrap{position:relative;display:flex;align-items:center;justify-content:center;width:48px;height:48px}.hdr-progress-ring{display:block}.hdr-ring-bg{fill:none;stroke:#ffffff0f;stroke-width:3}.hdr-ring-fill{fill:none;stroke:var(--green);stroke-width:3;stroke-linecap:round;transition:stroke-dashoffset .5s ease}.hdr-progress-pct{position:absolute;font-size:12px;font-weight:500;font-family:var(--mono);color:var(--green);line-height:1;letter-spacing:-.3px}.btn-hamburger{display:flex;flex-direction:column;justify-content:center;gap:5px;padding:8px 10px;background:none;border:none;cursor:pointer;border-radius:var(--r-sm);transition:background .15s}.btn-hamburger:hover{background:var(--bg-elevated)}.btn-hamburger span{display:block;width:20px;height:2px;background:var(--text-2);border-radius:2px;transition:transform .22s ease,opacity .22s ease,background .15s;transform-origin:center}.btn-hamburger:hover span{background:var(--text-1)}.btn-hamburger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg);background:var(--text-1)}.btn-hamburger.is-open span:nth-child(2){opacity:0}.btn-hamburger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);background:var(--text-1)}.task-panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:390;background:#00000073;opacity:0;pointer-events:none;transition:opacity .25s ease}.task-panel-overlay.is-open{opacity:1;pointer-events:all}.task-panel{position:fixed;top:0;right:0;width:380px;height:100vh;z-index:400;background:var(--task-panel-bg);border-left:1px solid rgba(56,189,248,.12);display:flex;flex-direction:column;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:-8px 0 32px #00000080}.task-panel.is-open{transform:translate(0)}.task-panel-hdr{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.task-panel-title{font-size:13px;font-weight:600;color:var(--text-3);letter-spacing:1px;text-transform:uppercase}.task-panel-close{background:none;border:none;color:var(--text-3);font-size:18px;cursor:pointer;padding:2px 6px;border-radius:var(--r-xs);line-height:1;transition:color .15s,background .15s}.task-panel-close:hover{color:var(--text-1);background:var(--bg-elevated)}.task-panel-body{flex:1;overflow-y:auto;padding:14px 14px 0;display:flex;flex-direction:column;align-items:stretch}.task-panel-empty{padding:16px 8px 12px;margin:0;font-size:15px;color:var(--text-3)}.tp-index{min-height:0}.tp-index-list{list-style:none;margin:0;padding:0 0 16px;display:flex;flex-direction:column;gap:12px}.tp-index-section{position:relative;border-radius:var(--r-sm);border:1px solid rgba(56,189,248,.22);background:radial-gradient(ellipse 120% 70% at 50% 0%,rgba(56,189,248,.14) 0%,transparent 62%),linear-gradient(180deg,#1e3d62,#173352 48%,#122a46);box-shadow:0 1px #ffffff0f inset,0 -1px #0000002e inset,0 6px 16px #00000061,0 2px 6px #00000047;overflow:hidden;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.tp-index-section:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;border-radius:inherit;background:#38bdf814;opacity:0;pointer-events:none;transition:opacity .12s ease}.tp-index-section:hover:before{opacity:1}.tp-index-section.is-active:before{background:#38bdf80d}.tp-index-section.is-active{border-color:#38bdf894;background:linear-gradient(var(--teal),var(--teal)) 0 0 / 3px 100% no-repeat,radial-gradient(ellipse 120% 70% at 50% 0%,rgba(56,189,248,.16) 0%,transparent 62%),linear-gradient(180deg,#21476f,#1a3a5e 48%,#14304f);box-shadow:0 1px #ffffff1a inset,0 -1px #00000026 inset,0 0 0 1px #38bdf852,0 8px 24px #0000006b,0 4px 18px #38bdf847}.tp-index-section.is-starting.is-active{box-shadow:0 1px #ffffff1a inset,0 -1px #00000026 inset,0 0 0 1px #38bdf861,0 8px 28px #00000073,0 4px 22px #38bdf852}.tp-index-section.is-expanded{background:transparent}.tp-index-section.is-active.is-expanded{border-color:#38bdf89e;background:linear-gradient(var(--teal),var(--teal)) 0 0 / 3px 100% no-repeat;box-shadow:0 0 0 1px #38bdf85c,0 8px 24px #0000006b,0 4px 20px #38bdf84d}.tp-index-section.is-expanded .tp-index-section-hdr{background:radial-gradient(ellipse 120% 70% at 50% 0%,rgba(56,189,248,.14) 0%,transparent 62%),linear-gradient(180deg,#1e3d62,#173352 48%,#122a46)}.tp-index-section.is-active.is-expanded .tp-index-section-hdr{background:linear-gradient(var(--teal),var(--teal)) 0 0 / 3px 100% no-repeat,radial-gradient(ellipse 120% 70% at 50% 0%,rgba(56,189,248,.16) 0%,transparent 62%),linear-gradient(180deg,#21476f,#1a3a5e 48%,#14304f)}.tp-index-section.is-expanded:hover:before{opacity:0}.tp-index-section.is-expanded .tp-index-section-hdr:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:#38bdf814;opacity:0;pointer-events:none;transition:opacity .12s ease}.tp-index-section.is-expanded .tp-index-section-hdr:hover:after{opacity:1}.tp-index-section.is-active.is-expanded .tp-index-section-hdr:after{background:#38bdf80d}.tp-index-section-hdr{position:relative;z-index:1;display:flex;align-items:flex-start;gap:4px;padding:4px 4px 4px 16px;cursor:pointer}.tp-index-section-hdr:focus-visible{outline:2px solid rgba(56,189,248,.45);outline-offset:-2px}.tp-index-chevron-btn{flex-shrink:0;width:32px;height:32px;margin-top:6px;display:grid;place-items:center;border:none;border-radius:var(--r-xs);background:transparent;color:var(--text-3);cursor:pointer;transition:background .12s ease,color .12s ease}.tp-index-chevron-btn:hover{color:var(--text-1)}.tp-index-chevron{width:16px;height:16px;flex-shrink:0;transition:transform .2s ease}.tp-index-section.is-expanded .tp-index-chevron{transform:rotate(180deg)}.tp-index-chevron-spacer{flex-shrink:0;width:32px;height:1px}.tp-index-task-link{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px;padding:10px 4px 12px 0;pointer-events:none}.tp-index-title-row{display:flex;align-items:flex-start;gap:10px}.tp-index-num{flex-shrink:0;width:24px;min-width:24px;font-family:var(--mono);font-size:14px;font-weight:700;color:#38bdf8b8;letter-spacing:.3px;padding-top:2px}.tp-index-section.is-active .tp-index-num{color:var(--teal)}.tp-index-title{flex:1;min-width:0;font-size:15px;font-weight:var(--fw-medium);color:var(--text-1);line-height:1.4;opacity:.9}.tp-index-section.is-active .tp-index-title{color:#ecfdf5;opacity:1}.tp-index-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding-left:28px}.tp-index-meta .file-type-icon{flex-shrink:0}.task-file-icon .file-type-icon:not(.is-submitted),.tp-index-meta .file-type-icon:not(.is-submitted){color:#e4611a!important}.task-file-icon .file-type-icon.is-submitted,.tp-index-meta .file-type-icon.is-submitted{color:var(--green)!important}.tp-index-file{font-family:var(--mono);font-size:13px;color:var(--text-2)}.tp-index-score{margin-left:6px;font-family:var(--mono);font-size:12px;font-weight:600;padding:2px 8px;border-radius:99px;border:1px solid transparent}.tp-index-score--red{color:#f87171;background:#f871711a;border-color:#f8717140}.tp-index-score--blue{color:var(--score-gold);background:var(--score-gold-dim);border-color:var(--score-gold-mid)}.tp-index-score--green{color:var(--green);background:#34d3991a;border-color:#34d39940}.tp-index-status{flex-shrink:0;width:18px;margin:12px 4px 0 0}.tp-index-status--done{color:var(--green)}.tp-index-sublist{position:relative;z-index:1;list-style:none;margin:0;padding:10px 12px 12px 16px;display:none;flex-direction:column;gap:2px;border-top:1px solid rgba(56,189,248,.34);background:#050c1a6b;box-shadow:inset 0 1px #38bdf81f,inset 0 8px 16px #0000001f}.tp-index-section.is-expanded .tp-index-sublist{display:flex}.tp-index-section.is-active.is-expanded .tp-index-sublist{border-top-color:#38bdf86b;background:linear-gradient(var(--teal),var(--teal)) 0 0 / 3px 100% no-repeat,#040a1685;box-shadow:inset 0 1px #38bdf81f,inset 0 8px 16px #0000001f}.tp-index-sub-row{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px 8px 34px;border-radius:var(--r-xs);pointer-events:none}.tp-index-sub-num{flex-shrink:0;min-width:28px;font-family:var(--mono);font-size:14px;font-weight:var(--fw-medium);letter-spacing:.2px;color:var(--text-3);line-height:1.45}.tp-index-sub-title{flex:1;min-width:0;font-family:var(--font);font-size:14px;font-weight:var(--fw-medium);line-height:1.45;color:var(--text-2)}.breadcrumb{display:flex;align-items:center;gap:6px;font-size:18px}.bc-item{color:var(--text-3)}.bc-sep{color:var(--border-2);font-size:17px}.bc-active{color:var(--text-2);font-weight:500}.progress-wrap{display:flex;align-items:center;gap:8px}.progress-label{font-size:17px;color:var(--text-3);white-space:nowrap}.progress-track{width:72px;height:3px;background:var(--border);border-radius:99px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--teal),var(--blue));border-radius:99px;transition:width .5s ease}.btn{font-family:var(--font);font-weight:500;cursor:pointer;border-radius:var(--r-sm);border:none;transition:all .15s ease;white-space:nowrap}.btn-ghost{font-size:18px;padding:5px 11px;background:transparent;border:1px solid var(--border);color:var(--text-3)}.btn-ghost:hover{color:var(--text-2);border-color:var(--border-2)}.btn-run,.btn-save{display:flex;align-items:center;gap:6px;font-size:16px;font-weight:600;padding:0 13px;height:32px;background:var(--green-dim);border:1px solid var(--green-mid);color:var(--green)}.btn-run:hover,.btn-save:hover{background:var(--green-mid);border-color:var(--green);box-shadow:0 0 14px #34d3992e}.btn-run:active,.btn-save:active{transform:scale(.97)}.btn-save:disabled{opacity:.85;cursor:wait}.btn-save-icon{flex-shrink:0}.btn-save-spinner{width:12px;height:12px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:btn-save-spin .65s linear infinite}@keyframes btn-save-spin{to{transform:rotate(360deg)}}.btn-submit{display:flex;align-items:center;gap:7px;font-size:16px;font-weight:700;padding:0 16px;height:32px;background:var(--green);color:#061a12;border:1px solid transparent}.btn-submit:hover{background:#5eead4;box-shadow:0 0 16px #2dd4bf47}.btn-submit-icon{flex-shrink:0}.btn-submit:disabled{cursor:not-allowed;box-shadow:none}.btn-submit:disabled:not(.is-submitted):not(.is-evaluating){opacity:.42}.btn-submit:disabled:hover{background:var(--green);box-shadow:none}.btn-submit.is-submitted:disabled{opacity:.42}.btn-submit.is-evaluating:disabled{opacity:.85;cursor:wait}.btn-help{display:flex;align-items:center;gap:0;font-size:16px;font-weight:600;padding:0 14px;height:32px;background:var(--teal-dim);color:var(--teal);border:1px solid var(--border-teal)}.btn-help:hover{background:var(--teal-mid);border-color:#38bdf880;box-shadow:0 0 12px #38bdf82e}.btn-help svg{margin-right:-1px;margin-left:-4px}.app-body{display:flex;flex:1;overflow:hidden;min-height:0;margin-top:var(--header-h);height:calc(100% - var(--header-h))}.col-task{width:var(--left-col-w);min-width:var(--task-col-min-w, 280px);flex-shrink:0;position:relative;background:radial-gradient(ellipse 90% 40% at 50% 0%,rgba(56,189,248,.07) 0%,transparent 70%),linear-gradient(180deg,#0e1f3a,#0b1828);border-left:1px solid rgba(56,189,248,.18);overflow:hidden;display:flex;flex-direction:column;padding:0 18px;gap:0;transition:width .22s ease,min-width .22s ease,padding .22s ease,border-color .22s ease}.col-task.is-collapsed{width:0!important;min-width:0!important;flex:0 0 0!important;padding:0;border-left-color:transparent;overflow:visible}.col-task.is-collapsed .col-task-scroll,.col-task.is-collapsed .task-help-bar,.app-body.is-task-panel-collapsed .col-resizer,#app.is-task-panel-collapsed .col-resizer{display:none}.task-col-floating-toggle{position:fixed;right:var(--task-col-toggle-right);z-index:120;display:inline-flex;align-items:center;justify-content:center;width:var(--task-col-toggle-size);height:var(--task-col-toggle-size);padding:0;background:#38bdf838;border:1px solid rgba(56,189,248,.55);border-radius:var(--r-sm);color:#38bdf8;box-shadow:none;cursor:pointer;transition:background .16s ease,border-color .16s ease,box-shadow .16s ease,color .16s ease}.task-col-floating-toggle:hover{background:#38bdf857;border-color:#38bdf8d9;color:#7dd3fc;box-shadow:none}#app.is-task-panel-collapsed .task-col-floating-toggle{box-shadow:0 2px 10px #38bdf833}#app.is-task-panel-collapsed .task-col-floating-toggle:hover{box-shadow:0 4px 18px #38bdf852}.task-col-eye-toggle{top:calc(var(--header-h) + 11px)}.task-eye-slash{opacity:1}#app.is-task-panel-collapsed .task-eye-slash{opacity:0}.task-col-help-toggle{display:none;top:calc(var(--header-h) + 11px + var(--task-col-toggle-size) + 8px)}.task-col-help-toggle svg{width:21px;height:21px;flex-shrink:0}#app.is-task-panel-collapsed .task-col-help-toggle{display:inline-flex}.col-task-scroll{flex:1;min-height:0;overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain;scroll-behavior:smooth;padding-bottom:16px;scrollbar-width:none;-ms-overflow-style:none}.col-task-scroll::-webkit-scrollbar{width:0;height:0}.col-task-scroll.is-task-help-mode{overscroll-behavior:auto;scroll-behavior:auto;scroll-padding-top:var(--task-help-scroll-padding, 90px)}.task-help-bar{flex-shrink:0;height:var(--task-help-bar-h, 52px);display:flex;align-items:center;margin:0 -18px;padding:0 18px;background:#070d18;border-top:1px solid rgba(255,255,255,.04)}.task-help-default,.task-help-player{width:100%}.task-help-default-actions{--task-nav-btn-w: 84px;display:grid;grid-template-columns:minmax(0,1fr);gap:10px;width:100%}.task-help-default-actions.is-split{grid-template-columns:minmax(0,1fr) var(--task-nav-btn-w)}.task-help-default-actions.is-split.has-prev{grid-template-columns:var(--task-nav-btn-w) minmax(0,1fr) var(--task-nav-btn-w)}.task-help-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;align-items:center}.task-help-bar .btn-help-task,.task-help-bar .btn-back-to-task{flex-shrink:0;min-width:0;height:32px;min-height:32px;padding:0 12px;background:#38bdf838;border:1px solid rgba(56,189,248,.55);color:#38bdf8;box-shadow:0 2px 10px #38bdf833}.task-help-bar .btn-prev-task,.task-help-bar .btn-next-task{width:var(--task-nav-btn-w);min-width:var(--task-nav-btn-w);max-width:var(--task-nav-btn-w);flex-shrink:0;height:32px;min-height:32px;padding:0 10px;border-radius:var(--r-sm);font-size:14px;font-weight:600;gap:4px}.task-help-bar .btn-prev-task{background:#38bdf838;border:1px solid rgba(56,189,248,.55);color:#38bdf8;box-shadow:0 2px 10px #38bdf833}.task-help-bar .btn-prev-task:hover{background:#38bdf857;border-color:#38bdf8d9;color:#7dd3fc;box-shadow:0 4px 14px #38bdf847}.task-help-bar .btn-next-task{background:var(--teal);border:1px solid var(--teal);color:#000;box-shadow:0 2px 10px #38bdf847}#btn-prev-task[hidden],#btn-next-task[hidden]{display:none!important}.task-help-bar .btn-next-task:hover{background:#7dd3fc;border-color:#7dd3fc;color:#000;box-shadow:0 4px 14px #38bdf85c}.task-help-bar .btn-prev-task svg,.task-help-bar .btn-next-task svg{flex-shrink:0}.task-help-bar .btn-next-task svg{color:#000}.task-help-bar .help-audio-play{width:32px;height:32px}.task-help-bar .btn-help-task .btn-help-task-spark-wrap{margin-right:-1px;margin-left:-4px}.btn-help-task-spark-wrap{position:relative;flex-shrink:0;width:23px;height:23px}.btn-help-task-spark-wrap--compact{width:18px;height:18px}.btn-help-task-spark-wrap .btn-help-task-spark{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;display:block}.btn-help-task-spark--teal{opacity:0}.btn-help-task:hover .btn-help-task-spark--teal,.task-col-help-toggle:hover .btn-help-task-spark--teal{opacity:1}.btn-help-task:hover .btn-help-task-spark--blue,.task-col-help-toggle:hover .btn-help-task-spark--blue{opacity:0}.task-meta{position:sticky;top:0;z-index:10;margin:0 -18px 12px;padding:11px var(--task-meta-pad-r) 11px 18px;background:radial-gradient(ellipse 100% 60% at 50% 0%,rgba(56,189,248,.08) 0%,transparent 70%),linear-gradient(180deg,#122040,#0e1a36)}.task-meta:before{content:"";position:absolute;left:0;right:0;bottom:100%;height:48px;background:#122040;pointer-events:none}.task-meta:after{content:"";position:absolute;bottom:-20px;left:0;right:0;height:20px;background:linear-gradient(to bottom,rgba(14,26,54,.6),transparent);pointer-events:none}.task-meta-row{display:flex;align-items:center;flex-wrap:nowrap;gap:7px;margin-bottom:10px}.task-num-pill{display:inline-flex;align-items:center;gap:5px;flex-shrink:0;white-space:nowrap;font-size:14px;font-weight:500;line-height:1;text-transform:uppercase;letter-spacing:1px;color:var(--green);background:#34d3991a;border:1px solid rgba(52,211,153,.3);padding:5px 10px;border-radius:99px}.task-subtasks-pill{flex-shrink:0;white-space:nowrap;font-size:14px;font-weight:500;line-height:1;text-transform:uppercase;letter-spacing:1px;color:var(--text-3);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);padding:5px 10px;border-radius:99px}.task-score-pill{display:inline-flex;align-items:center;gap:6px;flex-shrink:0;white-space:nowrap;font-size:14px;font-weight:500;font-family:var(--mono);line-height:1;padding:5px 10px;border-radius:99px;border:1px solid transparent}.task-score-pill--red{color:#f87171;background:#f871711a;border-color:#f871714d}.task-score-pill--blue{color:var(--score-gold);background:var(--score-gold-dim);border-color:var(--score-gold-mid)}.task-score-pill--green{color:var(--green);background:#34d3991a;border-color:#34d3994d}.task-id-pill{font-family:var(--mono);font-size:16px;font-weight:600;letter-spacing:.2px;color:var(--text-3);background:var(--bg-input);border:1px solid var(--border);padding:2px 8px;border-radius:99px}.task-diff-pill{font-size:15px;font-weight:800;text-transform:uppercase;letter-spacing:.7px;padding:2px 8px;border-radius:99px;border:1px solid}.diff-beginner{color:var(--green);background:var(--green-dim);border-color:var(--green-mid)}.diff-intermediate{color:var(--amber);background:var(--amber-dim);border-color:#fbbf2440}.task-title{font-size:18px;font-weight:600;line-height:1.4;color:var(--text-1);margin-bottom:12px;letter-spacing:-.1px}.task-file-chip{display:inline-flex;align-items:center;gap:7px;font-size:14px;line-height:1;font-family:var(--mono);color:var(--teal);background:var(--teal-dim);border:1px solid var(--border-teal);padding:5px 10px;max-width:100%;overflow:hidden;border-radius:99px}.task-file-icon{display:flex;align-items:center;flex-shrink:0}#task-file-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.chip-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}.html-dot,.css-dot,.js-dot{background:#e4611a}.chip-label{font-family:var(--mono);font-size:14px;color:var(--text-3);font-weight:400;border-left:1px solid var(--border-teal);padding-left:7px;margin-left:2px}.subtask-deck{display:flex;flex-direction:column;gap:16px;padding-top:8px}.card-wrap{perspective:1400px;flex-shrink:0;position:relative;max-width:100%;min-width:0}.card-wrap.is-help-view{overflow:visible}.card-inner{position:relative;width:100%;max-width:100%;min-width:0;transition:transform .6s cubic-bezier(.4,.2,.2,1);transform-style:preserve-3d;will-change:transform}.card-inner.is-flipped{transform:rotateY(180deg)}.card-face{backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:var(--r);display:flex;flex-direction:column;overflow:hidden}.card-back{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.card-front{background:linear-gradient(160deg,#172c50,#12264a 60%,#0e2040) padding-box,linear-gradient(135deg,#38bdf8d9,#93c5fda6,#c4b5fd6b) border-box;border:1px solid transparent;box-shadow:0 1px #ffffff24 inset}.card-top-stripe{height:3px;flex-shrink:0;background:linear-gradient(90deg,#38bdf8,#93c5fd,#c4b5fd);opacity:.9}.card-hdr{display:flex;align-items:flex-start;justify-content:space-between;padding:16px;flex-shrink:0;cursor:pointer;-webkit-user-select:none;user-select:none;gap:8px}.card-hdr-left{display:flex;align-items:flex-start;gap:8px;flex:1;min-width:0}.card-chevron{width:16px;height:16px;flex-shrink:0;color:var(--text-3);margin-top:7px;transition:transform .2s ease}.card-back .card-hdr{cursor:default}.card-hdr-text{flex:1;min-width:0;line-height:1.5}.card-subtask-label{font-size:18px;font-weight:500;letter-spacing:.2px;color:var(--text-3);white-space:nowrap}.card-num-badge{display:flex;align-items:center;gap:8px}.badge-circle{width:24px;height:24px;border-radius:50%;background:var(--teal-dim);border:1px solid var(--border-teal);display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:800;color:var(--teal);flex-shrink:0}.badge-label{font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--text-3)}.card-of-label{font-size:16px;color:var(--text-3);font-family:var(--mono)}.card-body{flex:1;padding:0 16px 16px;display:flex;flex-direction:column;gap:16px;min-height:0;min-width:0;overflow-y:auto;overflow-x:hidden}.card-title{font-size:18px;font-weight:700;line-height:1.5;color:var(--teal);display:inline}.card-bullets{display:flex;flex-direction:column;gap:12px}.bullet-item{display:flex;align-items:flex-start;gap:10px;padding:20px;background:linear-gradient(135deg,#0e1c34e6,#091426f2);border:1px solid rgba(56,189,248,.13);border-radius:var(--r-sm);font-size:16px;line-height:1.6;color:var(--text-2);box-shadow:0 2px 8px #00000040,0 1px #ffffff08 inset;min-width:0}.bullet-item>span{flex:1;min-width:0;overflow-wrap:anywhere;word-break:break-word}.bullet-item code{font-family:var(--mono);font-size:1em;line-height:inherit;vertical-align:baseline;background:#a5c8ff17;color:var(--text-code);padding:1px 5px;border-radius:3px;overflow-wrap:anywhere;word-break:break-all}.bullet-icon{flex-shrink:0;width:16px;height:16px;border-radius:50%;background:var(--teal-dim);border:1px solid var(--border-teal);display:flex;align-items:center;justify-content:center;margin-top:5px}.bullet-icon svg{display:block}.bullet-icon-mic{width:18px;height:18px;background:transparent;border:none;color:#b8cfe8b8}.card-footer{padding:12px 16px 16px;border-top:none;flex-shrink:0}.btn-flip{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:7px 12px;min-height:39px;background:#38bdf838;border:1px solid rgba(56,189,248,.55);border-radius:var(--r-sm);color:#38bdf8;font-size:16px;font-weight:600;font-family:var(--font);cursor:pointer;box-shadow:0 2px 10px #38bdf833;transition:background .16s ease,border-color .16s ease,box-shadow .16s ease,color .16s ease,transform .16s ease;letter-spacing:.15px}.btn-flip:hover{background:#38bdf857;border-color:#38bdf8d9;color:#7dd3fc;box-shadow:0 4px 18px #38bdf852;transform:translateY(-1px)}.btn-flip:active{transform:translateY(0)}.flip-icon{font-size:20px;opacity:1;color:inherit;display:inline-block;transition:transform .3s ease,color .16s ease}.btn-flip:hover .flip-icon{transform:rotate(180deg)}.card-back{background:linear-gradient(160deg,#172c50,#12264a 60%,#0e2040) padding-box,linear-gradient(135deg,#38bdf8d9,#93c5fda6,#c4b5fd6b) border-box;border:1px solid transparent;box-shadow:0 1px #ffffff24 inset;transform:rotateY(180deg)}.card-back-footer .btn-flip{border-color:#ffffff1f;color:#94a3b8;background:#ffffff0a}.card-back-footer .btn-flip:hover{border-color:#38bdf859;color:#cbd5e1;background:#38bdf814;box-shadow:0 4px 18px #38bdf81f}.card-back-stripe{height:3px;flex-shrink:0;background:linear-gradient(90deg,#38bdf8,#93c5fd,#c4b5fd);opacity:.95}.card-back-hdr{display:flex;align-items:center;gap:10px;padding:13px 16px 11px;border-bottom:1px solid rgba(45,212,191,.1);flex-shrink:0}.back-badge{width:22px;height:22px;border-radius:50%;background:var(--teal-mid);border:1px solid rgba(45,212,191,.35);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:800;color:var(--teal);flex-shrink:0}.back-hdr-text{display:flex;flex-direction:column;gap:1px}.back-label{font-size:16px;font-weight:800;text-transform:uppercase;letter-spacing:.7px;color:var(--teal)}.back-sublabel{font-size:16px;color:var(--text-3)}.card-back-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:0 16px;display:flex;flex-direction:column;gap:12px;min-height:0;min-width:0}.card-back .card-back-body{flex:0 1 auto}.card-wrap.is-help-view .card-inner{height:auto;overflow:visible}.card-wrap.is-help-view.is-help-scroll .card-inner{height:100%}.card-wrap.is-help-view .card-front{position:absolute;top:0;right:0;bottom:0;left:0}.card-wrap.is-help-view .card-face.card-back{position:relative;inset:auto;height:auto;display:flex;flex-direction:column;overflow:visible}.card-wrap.is-help-view .card-back-body{flex:0 1 auto;min-height:0;overflow-y:visible;padding-bottom:20px;display:flex;flex-direction:column;gap:12px}.card-wrap.is-help-view.is-help-scroll .card-face.card-back{height:100%;overflow:hidden}.card-wrap.is-help-view.is-help-scroll .card-back-body{flex:1;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.card-wrap.is-help-view .help-steps-card,.card-wrap.is-help-view .help-output-card{flex-shrink:0;overflow:visible}.card-wrap.is-help-view .card-back-actions{flex-shrink:0}.card-wrap.is-help-view.is-help-scroll .card-face{height:100%}.help-steps-card{padding:20px;background:linear-gradient(135deg,#0e1c34e6,#091426f2);border:1px solid rgba(56,189,248,.13);border-radius:var(--r-sm);box-shadow:0 2px 8px #00000040,0 1px #ffffff08 inset;display:flex;flex-direction:column;gap:12px;min-width:0}.help-step-row{display:flex;align-items:flex-start;gap:10px;font-size:16px;line-height:1.6;color:#b8cfe8b8;min-width:0}.help-step-row>span{flex:1;min-width:0;overflow-wrap:anywhere;word-break:break-word}.help-step-row code{font-family:var(--mono);font-size:1em;line-height:inherit;vertical-align:baseline;background:#a5c8ff0f;color:#a5c8ffb8;padding:1px 5px;border-radius:3px;overflow-wrap:anywhere;word-break:break-all}.help-output-card{padding:20px;background:linear-gradient(135deg,#0e1c34e6,#091426f2);border:1px solid rgba(56,189,248,.13);border-radius:var(--r-sm);box-shadow:0 2px 8px #00000040,0 1px #ffffff08 inset;min-width:0}.help-output-label{font-size:16px;font-weight:600;line-height:1.4;color:var(--text-1);margin-bottom:8px}.help-output-body{font-family:var(--mono);font-size:16px;font-weight:400;line-height:1.6;color:#a5c8ffb8;white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word}.card-back-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:18px;padding:0 16px 16px;flex-shrink:0;align-items:center}.help-audio-bar{display:flex;align-items:center;gap:10px;min-width:0;padding:0;background:transparent;border:none;border-radius:0}.card-back-actions .btn-flip{width:100%;height:auto}.help-audio-play{flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(56,189,248,.55);border-radius:50%;background:#38bdf838;color:#38bdf8;cursor:pointer;box-shadow:0 2px 10px #38bdf833;transition:background .16s ease,border-color .16s ease,box-shadow .16s ease,color .16s ease,transform .16s ease}.help-audio-play:hover{background:#38bdf857;border-color:#38bdf8d9;color:#7dd3fc;box-shadow:0 4px 18px #38bdf852;transform:translateY(-1px)}.help-audio-play:active{transform:translateY(0)}.help-audio-icon{display:block}.help-audio-icon-pause,.help-audio-play.is-playing .help-audio-icon-play{display:none}.help-audio-play.is-playing .help-audio-icon-pause{display:block}.help-audio-track-wrap{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.help-audio-seek{--seek-pct: 0%;width:100%;height:12px;margin:0;padding:0;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:transparent;border:none;border-radius:99px;cursor:pointer}.help-audio-seek::-webkit-slider-runnable-track{height:4px;border-radius:99px;background:linear-gradient(to right,rgba(147,197,253,.32) 0%,rgba(147,197,253,.32) var(--seek-pct, 0%),rgba(255,255,255,.12) var(--seek-pct, 0%),rgba(255,255,255,.12) 100%)}.help-audio-seek::-moz-range-track{height:4px;border-radius:99px;background:#ffffff1f;border:none}.help-audio-seek::-moz-range-progress{height:4px;border-radius:99px;background:#93c5fd52;border:none}.help-audio-seek::-webkit-slider-thumb{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:12px;height:12px;margin-top:-4px;border-radius:50%;background:#38bdf8;border:2px solid #0c2040;cursor:pointer}.help-audio-seek::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:#38bdf8;border:2px solid #0c2040;cursor:pointer;box-sizing:border-box}.help-audio-times{display:flex;justify-content:space-between;font-size:12px;font-family:var(--mono);font-weight:500;color:var(--text-3);line-height:1}.help-audio-current{color:#38bdf8}.how-step{display:flex;align-items:flex-start;gap:10px;padding:9px 10px;border-radius:var(--r-sm);background:linear-gradient(135deg,#0a162af2,#07101efa);border:1px solid rgba(56,189,248,.11);box-shadow:0 2px 8px #0000004d,0 1px #ffffff08 inset;min-width:0;max-width:100%}.how-step-num{flex-shrink:0;width:20px;height:20px;border-radius:50%;background:#2dd4bf12;border:1px solid rgba(45,212,191,.18);display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:800;color:var(--teal);margin-top:2px}.how-step p{flex:1;min-width:0;font-size:16px;line-height:1.6;color:var(--text-2);margin:0;overflow-wrap:anywhere;word-break:break-word}.how-step p code{font-family:var(--mono);font-size:1em;line-height:inherit;vertical-align:baseline;background:#a5c8ff17;color:var(--text-code);padding:1px 5px;border-radius:3px;overflow-wrap:anywhere;word-break:break-all;white-space:normal}.how-output{border-radius:var(--r-sm);overflow:hidden;border:1px solid rgba(45,212,191,.18);flex-shrink:0;margin-top:4px}.how-output-hdr{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#2dd4bf0d;border-bottom:1px solid rgba(45,212,191,.1)}.how-output-dot{width:6px;height:6px;border-radius:50%;background:var(--teal);opacity:.7}.how-output-label{font-size:15px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-3)}.how-output pre{margin:0;padding:12px 14px;background:var(--bg-output);font-family:var(--mono);font-size:17px;line-height:1.75;color:#86efac;overflow-x:auto;white-space:pre}.card-back-footer{padding:12px 16px 16px;flex-shrink:0}.col-code{flex:1;display:flex;overflow:hidden;min-width:0}.row-resizer{flex-shrink:0;height:4px;background:var(--border);cursor:row-resize;transition:background .15s;position:relative;z-index:20}.row-resizer:before{content:"";position:absolute;top:-4px;right:0;bottom:-4px;left:0}.row-resizer:hover,.row-resizer.is-dragging{background:#38bdf873}.col-resizer{flex-shrink:0;width:3px;background:var(--border);cursor:col-resize;transition:background .15s;position:relative;z-index:20}.col-resizer:before{content:"";position:absolute;top:0;right:-4px;bottom:0;left:-4px}.col-resizer:hover,.col-resizer.is-dragging{background:#38bdf873}.col-explorer{flex:0 0 12vw;width:12vw;background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:visible;position:relative;z-index:10;padding-bottom:0}.explorer-scroll-area{flex:1;overflow-y:auto;overflow-x:hidden;min-height:0;padding-bottom:37px}.explorer-hdr{padding:9px 14px;font-size:14px;font-weight:700;letter-spacing:.9px;text-transform:uppercase;color:var(--text-3);border-bottom:1px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:space-between}.explorer-section-label{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--text-3);padding:10px 14px 4px;opacity:.6}.tree-project{padding:0 0 8px}.tree-folder{display:flex;align-items:center;gap:5px;padding:5px 14px;font-size:14px;color:var(--text-2);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:var(--r-xs);transition:background .15s;min-width:0}.tree-folder:hover{background:#ffffff0a}.tree-chevron-icon{color:var(--text-3);flex-shrink:0;transition:transform .2s ease}.tree-chevron{font-size:15px;color:var(--text-3)}.tree-folder-icon{font-size:14px;color:var(--teal);opacity:.7}.tree-folder-name{font-size:14px;font-weight:500;font-family:var(--mono);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1}.tree-files{padding-left:14px}#certificate-tree-root{margin-top:14px}.tree-file{display:flex;align-items:center;gap:7px;padding:5px 14px 5px 22px;font-size:14px;font-family:var(--mono);color:var(--text-3);cursor:pointer;border-radius:3px;margin:1px 5px;transition:all .1s;-webkit-user-select:none;user-select:none;min-width:0}.tree-file:hover{background:#ffffff0a;color:var(--text-2)}.tree-file.is-active{background:var(--teal-dim);color:var(--teal);border-radius:var(--r-xs)}.tree-file .file-type-icon:not(.is-submitted){color:#e4611a}.tree-file .file-type-icon.is-submitted{color:var(--green)}.tree-file .file-type-icon--certificate-img{width:14px;height:14px;object-fit:contain}.performance-mascot-wrap{position:absolute;left:14px;bottom:47px;z-index:25;display:block;width:78px;height:78px;padding:0;overflow:hidden;border:3px solid rgba(56,189,248,.55);border-radius:50%;background:var(--approach-accent-bg);box-shadow:var(--approach-accent-glow),0 2px 10px #00000040;cursor:pointer;-webkit-user-select:none;user-select:none;transition:border-color .16s ease,box-shadow .16s ease,transform .15s ease}.performance-mascot{display:block;width:78px;height:78px;border-radius:50%;object-fit:cover;pointer-events:none;transform:scale(1.18)}.performance-mascot-wrap:hover{border-color:#38bdf8d9;box-shadow:inset 0 0 28px #38bdf81a,0 4px 14px #38bdf838;transform:scale(1.04)}.performance-mascot-wrap:focus-visible{outline:2px solid rgba(56,189,248,.55);outline-offset:2px}.submitted-drawer{position:absolute;bottom:0;left:0;right:0;z-index:20;display:flex;flex-direction:column;background:var(--bg-sidebar);overflow:hidden;transition:height .25s cubic-bezier(.4,0,.2,1)}.submitted-drawer.is-open{height:auto}.submitted-drawer-hdr{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;cursor:pointer;-webkit-user-select:none;user-select:none;flex-shrink:0;transition:background .12s}.submitted-drawer-hdr:hover{background:#ffffff08}.submitted-drawer-left{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--text-3);opacity:.6}.submitted-drawer-chevron{color:var(--text-3);flex-shrink:0;transform:rotate(0);transition:transform .25s ease}.submitted-drawer.is-open .submitted-drawer-chevron{transform:rotate(90deg)}.submitted-resize-handle{height:4px;background:var(--border);cursor:row-resize;flex-shrink:0;position:relative;z-index:20;transition:background .15s;display:none}.submitted-resize-handle:before{content:"";position:absolute;top:-4px;right:0;bottom:-4px;left:0}.submitted-drawer.is-open .submitted-resize-handle{display:block}.submitted-resize-handle:hover,.submitted-resize-handle.dragging{background:#38bdf873}.submitted-list{display:none;flex-direction:column;gap:6px;padding:0 8px 16px;overflow-y:auto;flex:1;min-height:0}.perf-empty-state{margin:8px 6px 0;font-size:13px;font-family:var(--mono);line-height:1.5;color:var(--text-3);text-align:center}.perf-file-group{display:flex;flex-direction:column;gap:5px;padding:8px 10px;background:#ffffff0d;border-radius:var(--r-xs)}.perf-file-row{display:flex;align-items:center;gap:7px;min-width:0}.perf-file-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1;font-size:14px;font-family:var(--mono);font-weight:var(--fw-regular);color:var(--text-2)}.perf-task-row{display:flex;align-items:center;gap:7px;padding-left:15px;min-width:0;font-size:13px;font-family:var(--mono)}.perf-task-label{flex-shrink:0;font-weight:var(--fw-regular);color:var(--text-2)}.submitted-tick{flex-shrink:0;color:var(--green)}.submitted-score-value--red{color:#f87171}.submitted-score-value--blue{color:var(--score-gold)}.submitted-score-value--green{color:var(--green)}.tree-file-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1}[data-tooltip]:not(.task-col-floating-toggle){position:relative}[data-tooltip]:not(.task-col-floating-toggle):after{content:attr(data-tooltip);position:absolute;left:calc(100% + 8px);top:50%;bottom:auto;transform:translateY(-50%);background:#1a2d4a;color:var(--text-1);font-size:14px;font-family:var(--mono);padding:4px 10px;border-radius:6px;border:1px solid var(--border-2);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s ease;z-index:1000;box-shadow:0 4px 14px #0006}.explorer-scroll-area [data-tooltip]:after,.submitted-list [data-tooltip]:after,.output-actions [data-tooltip]:after,.task-help-bar [data-tooltip]:after,.task-col-floating-toggle[data-tooltip]:after,.guidance-composer [data-tooltip]:after,#hdr-breadcrumb-prefix[data-tooltip]:after{content:none;display:none}.explorer-floating-tooltip{position:fixed;z-index:2000;background:#1a2d4a;color:var(--text-1);font-size:14px;font-family:var(--mono);padding:4px 10px;border-radius:6px;border:1px solid var(--border-2);white-space:nowrap;pointer-events:none;box-shadow:0 4px 14px #0006;transform:translateY(-50%)}.explorer-floating-tooltip.is-multiline{display:block;white-space:pre-line;width:auto;max-width:min(380px,calc(100vw - 24px));line-height:1.45;box-sizing:border-box;text-align:center}.explorer-floating-tooltip.is-starting-locked{background:#281c20f0;color:#f0dede;border-color:#fb929257;box-shadow:0 4px 14px #00000052}.explorer-floating-tooltip.is-starting-locked.is-multiline{color:#ebcaca}.explorer-floating-tooltip[hidden]{display:none!important}[data-tooltip]:not(.task-col-floating-toggle):hover:after{opacity:1}.file-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0;background:#e4611a}.file-type-icon{flex-shrink:0;display:block;color:#e4611a}.file-type-icon--html,.file-type-icon--css,.file-type-icon--js,.file-type-icon--markdown{color:#e4611a}.file-type-icon--ts{color:#3178c6}.file-type-icon--python{color:#ffd845}.file-type-icon--java{color:#e76f51}.perf-file-row .file-type-icon{color:var(--text-2)}.file-dot.is-submitted{background:var(--green)!important}.file-type-icon.is-submitted{color:var(--green)!important}.explorer-task-info{padding:0 12px 10px;display:flex;flex-direction:column;gap:4px}.etask-row{display:flex;align-items:center;gap:6px;font-size:16px;color:var(--text-3);padding:3px 0}.etask-dot{width:5px;height:5px;border-radius:50%;background:var(--teal);opacity:.6;flex-shrink:0}.etask-label{color:var(--teal);font-weight:600}.col-editor-wrap{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;background:var(--bg-editor)}.editor-tabbar{height:36px;flex-shrink:0;display:flex;align-items:stretch;background:var(--bg-tabbar);border-bottom:1px solid rgba(0,0,0,.4);overflow-x:auto}.editor-tabbar[hidden]{display:none!important}.editor-tabbar::-webkit-scrollbar{height:0}.editor-tab{display:flex;align-items:center;gap:7px;padding:0 16px;font-size:14px;font-family:var(--mono);color:var(--text-3);cursor:pointer;border-right:1px solid rgba(0,0,0,.2);-webkit-user-select:none;user-select:none;position:relative;flex-shrink:0;transition:color .12s}.editor-tab:hover{color:var(--text-2);background:#ffffff08}.editor-tab.is-active{background:var(--bg-editor);color:var(--text-1)}.editor-tab.is-active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--teal)}.tab-file-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}.tab-close{font-size:20px;color:var(--text-3);opacity:1;line-height:1;padding:0 2px}.editor-tab:hover .tab-close{color:var(--text-1)}.editor-pane{flex:1;min-height:0;overflow:hidden;position:relative;display:flex;flex-direction:column}.monaco-editor-host{flex:1;min-height:0;position:relative}.monaco-editor-host.is-hidden{display:none}.approach-voice-pane{display:none;flex-direction:column;min-height:0;min-width:0;width:100%;max-width:100%;overflow-y:auto;background:var(--approach-accent-bg);box-shadow:var(--approach-accent-glow)}.approach-voice-inner{flex:1 1 0%;display:flex;flex-direction:column;align-items:stretch;justify-content:center;gap:28px;width:100%;max-width:100%;min-width:0;box-sizing:border-box;padding:24px 20px;text-align:center}.approach-voice-inner>*{min-width:0;max-width:100%;box-sizing:border-box}.approach-voice-title-wrap{width:100%;min-width:0;max-width:100%;flex:0 1 auto}.approach-voice-title{margin:0;display:block;flex:0 1 auto;width:100%;max-width:100%;min-width:0;box-sizing:border-box;font-size:16px;font-weight:var(--fw-semibold);line-height:1.55;letter-spacing:.1px;color:var(--text-1);white-space:normal;overflow-wrap:anywhere;word-wrap:break-word;word-break:break-word;-webkit-hyphens:auto;hyphens:auto}.approach-voice-desc{margin:0;max-width:420px;font-size:13px;line-height:1.55;color:var(--text-3)}.approach-voice-controls{display:flex;align-items:center;justify-content:center;align-self:center;width:100%;max-width:100%;min-width:0}.approach-voice-start-block{display:flex;justify-content:center;width:100%;max-width:100%;min-width:0}.approach-voice-start-hint,.approach-voice-status{margin:0;font-size:13px;font-weight:400;line-height:1.55;color:var(--text-3);text-align:center}.approach-start-recording-btn{position:relative;display:inline-flex;align-items:center;gap:7px;height:32px;padding:0 16px;border-radius:var(--r-sm);border:1px solid var(--teal);background:var(--teal);color:#000;font-size:16px;font-weight:700;line-height:1;cursor:pointer;overflow:hidden;isolation:isolate;transition:background .15s ease,box-shadow .15s ease}.approach-start-recording-btn:after{content:"";position:absolute;top:0;left:0;width:55%;height:100%;background:linear-gradient(105deg,transparent 18%,rgba(255,255,255,.55) 50%,transparent 82%);transform:translate(-150%) skew(-22deg);animation:approachStartRecordingShine 2.8s linear infinite;pointer-events:none}.approach-start-recording-btn:hover{background:#5eccff;box-shadow:0 0 16px #38bdf852}.approach-start-recording-btn svg{position:relative;z-index:1;display:block;flex-shrink:0;width:16px;height:16px}.approach-start-recording-btn-label{position:relative;z-index:1}@keyframes approachStartRecordingShine{0%{transform:translate(-150%) skew(-22deg)}40%{transform:translate(350%) skew(-22deg)}to{transform:translate(350%) skew(-22deg)}}.approach-voice-start-block[hidden],.approach-voice-start-hint[hidden],.approach-voice-status[hidden],.approach-voice-recorder-row[hidden]{display:none!important}.approach-voice-recorder-row{width:fit-content;max-width:100%}.approach-recorder-row,.approach-help-recorder-row{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:nowrap;width:fit-content;max-width:100%}.approach-recorder-row .approach-record-btn.approach-help-stop-resume-btn,.approach-help-recorder-row .approach-record-btn.approach-help-stop-resume-btn{height:32px;min-height:32px;max-height:32px}.approach-recorder-row .approach-send-btn.approach-help-send-btn,.approach-help-recorder-row .approach-send-btn.approach-help-send-btn{flex-shrink:0;height:32px;min-height:32px;max-height:32px;padding:0 16px;box-sizing:border-box;display:inline-flex;align-items:center;gap:7px;font-size:16px;font-weight:700;line-height:1}.approach-voice-waveform{flex:1 1 160px;min-width:120px;max-width:240px;width:180px;height:32px;display:block;background:transparent;border:none}.approach-record-btn.is-resume{background:#38bdf838;border-color:#38bdf88c;color:#38bdf8}.approach-record-btn-icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.approach-record-btn{display:inline-flex;align-items:center;gap:8px;height:40px;padding:0 16px;border-radius:var(--r-sm);border:1px solid rgba(56,189,248,.55);background:#38bdf838;color:#38bdf8;font-size:14px;font-weight:var(--fw-semibold);cursor:pointer;transition:background .16s ease,border-color .16s ease}.approach-record-btn:hover{background:#38bdf857;border-color:#38bdf8d9}.approach-record-btn.is-recording{background:#f871712e;border-color:#f87171a6;color:#f87171}.approach-record-timer{min-width:42px;font-family:var(--mono);font-size:14px;font-weight:var(--fw-semibold);color:#38bdf8;flex-shrink:0}.approach-record-timer:not([hidden]){display:inline-block}.approach-send-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;height:40px;padding:0 18px;background:var(--teal);border:1px solid var(--teal);color:#000;font-weight:var(--fw-bold)}.approach-send-btn:disabled{opacity:.42;cursor:not-allowed}.approach-send-btn.is-loading,.approach-send-btn.is-action-loading{opacity:.42;cursor:wait;pointer-events:none}.approach-send-btn.is-loading:disabled,.approach-send-btn.is-action-loading:disabled{opacity:.42}.approach-send-spinner{width:14px;height:14px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:approach-send-spin .65s linear infinite;flex-shrink:0}@keyframes approach-send-spin{to{transform:rotate(360deg)}}.output-action-wrap{display:inline-flex}.output-action-wrap[data-tooltip] .btn-save:disabled,.output-action-wrap[data-tooltip] .btn-run:disabled{pointer-events:none}.output-action-wrap[data-tooltip]{cursor:not-allowed}#app.is-task-starting .output-action-wrap[data-tooltip] .btn-save:disabled,#app.is-task-starting .output-action-wrap[data-tooltip] .btn-run:disabled{border-width:3px}#app.is-task-starting .btn-help-task[aria-disabled=true],#app.is-task-starting .task-col-help-toggle[aria-disabled=true]{opacity:.42;cursor:not-allowed;border-width:2px}#app.is-task-starting .task-col-help-toggle[aria-disabled=true]:hover{background:#38bdf838;border-color:#38bdf88c;color:#38bdf8;box-shadow:none}#app.is-task-starting .guidance-composer.is-starting-locked .guidance-quick-btn,#app.is-task-starting .guidance-composer.is-starting-locked .guidance-or-divider,#app.is-task-starting .guidance-composer.is-starting-locked .guidance-voice-btn,#app.is-task-starting .guidance-composer.is-starting-locked .guidance-send-btn{opacity:.42;cursor:not-allowed}#app.is-task-starting .guidance-composer.is-starting-locked .guidance-input-wrap.is-starting-ready{border-color:#38bdf8b8;box-shadow:0 0 0 3px #60a5fa1a}#app.is-task-starting .guidance-composer.is-starting-locked .guidance-input-wrap.is-starting-ready.is-empty .guidance-input-field:after{animation:none;opacity:1}#app.is-task-starting .guidance-composer.is-starting-locked .guidance-input{cursor:text;pointer-events:none}#app.is-approach-feedback-received .approach-voice-pane{display:none!important}#app.is-approach-feedback-received .guidance-chat-scroll{gap:14px}#app.is-approach-feedback-received .guidance-composer{margin-top:0;padding-top:0}#app.is-approach-feedback-received .guidance-composer-inner:has(.approach-help-actions:not([hidden])) .guidance-composer-check-stack,#app.is-approach-feedback-received .guidance-composer-inner:has(.approach-help-recorder:not([hidden])) .guidance-composer-check-stack{margin-top:22px}.approach-help-actions[hidden],.approach-help-recorder[hidden]{display:none!important}.approach-help-actions{grid-column:1 / -1;justify-self:end;display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap;width:fit-content;max-width:100%}.approach-help-record-again-btn{display:inline-flex;align-items:center;gap:7px;height:32px;padding:0 16px;border-radius:var(--r-sm);border:1px solid rgba(56,189,248,.55);background:#38bdf838;color:#38bdf8;font-size:16px;font-weight:700;line-height:1;cursor:pointer;transition:background .16s ease,border-color .16s ease}.approach-help-record-again-btn:hover{background:#38bdf857;border-color:#38bdf8d9}.approach-help-start-task-btn{min-width:0}.approach-help-recorder{grid-column:1 / -1;justify-self:end;width:fit-content;max-width:100%}.approach-help-stop-resume-btn{flex-shrink:0;width:32px;min-width:32px;height:32px;min-height:32px;max-height:32px;padding:0;box-sizing:border-box;justify-content:center;border-radius:var(--r-sm)}.approach-help-stop-resume-btn .approach-record-btn-icon svg{width:18px;height:18px}.approach-help-waveform{flex:1 1 160px;min-width:120px;max-width:240px;width:180px;height:32px;display:block;background:transparent;border:none}.approach-help-recorder-timer{flex-shrink:0;min-width:42px;font-family:var(--mono);font-size:14px;font-weight:var(--fw-semibold);color:#38bdf8}.approach-help-cancel-btn{flex-shrink:0;width:32px;min-width:32px;height:32px;min-height:32px;max-height:32px;padding:0;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r-sm);border:1px solid rgba(148,163,184,.45);background:#94a3b81f;color:#cbd5e1;cursor:pointer;transition:background .16s ease,border-color .16s ease}.approach-help-cancel-btn svg{display:block;flex-shrink:0}.approach-help-cancel-btn:hover{background:#94a3b838;border-color:#94a3b8a6}.approach-help-send-btn svg{display:block;flex-shrink:0;width:16px;height:16px}#app.is-task-starting .guidance-composer.is-starting-locked .guidance-composer-check-wrap,#app.is-task-starting .guidance-composer.is-starting-locked .guidance-input-wrap{cursor:not-allowed}#app.is-task-starting.is-approach-split .editor-pane{display:grid;grid-template-rows:1fr 1fr;min-width:0}#app.is-task-starting.is-approach-split .monaco-editor-host{min-height:0;min-width:0;border-bottom:1px solid var(--border);cursor:not-allowed}#app.is-task-starting.is-approach-split .monaco-editor-host .monaco-editor,#app.is-task-starting.is-approach-split .monaco-editor-host .monaco-editor .margin,#app.is-task-starting.is-approach-split .monaco-editor-host .monaco-editor .monaco-scrollable-element{cursor:not-allowed}#app.is-task-starting.is-approach-full .monaco-editor-host,#app.is-task-starting.is-approach-full .editor-placeholder{display:none!important}#app.is-task-starting.is-approach-full .editor-pane,#app.is-task-starting.is-approach-split .editor-pane{min-height:0;min-width:0}#app.is-task-starting.is-approach-full .approach-voice-pane,#app.is-task-starting.is-approach-split .approach-voice-pane{display:flex;min-height:0;min-width:0;width:100%;max-width:100%}.editor-placeholder{position:absolute;top:14px;left:64px;height:22px;display:flex;align-items:center;pointer-events:none;z-index:1;font-family:JetBrains Mono,Fira Code,monospace;font-size:15.5px;color:#78a0c84d;white-space:pre;-webkit-user-select:none;user-select:none}.certificate-view-pane{display:none}#app.is-certificate-view .certificate-view-pane{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;background:radial-gradient(ellipse 80% 50% at 50% -10%,rgba(45,212,191,.08),transparent 55%),linear-gradient(180deg,#0e1929,#111827)}.certificate-view-pane[hidden]{display:none!important}.certificate-view-body{flex:1;min-height:0;display:flex;align-items:center;justify-content:center;overflow:auto;padding:32px 40px 24px}.certificate-preview-wrap{display:inline-block;max-width:min(100%,720px);max-height:100%;line-height:0}.certificate-view-image{display:block;max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;border-radius:8px;box-shadow:0 12px 40px #0006}.certificate-view-footer{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 20px 16px;background:#070d18;border-top:1px solid rgba(255,255,255,.06)}.certificate-overall-score{display:flex;align-items:center;gap:10px;min-width:0}.certificate-footer-actions{display:flex;align-items:center;gap:14px;flex-shrink:0;margin-left:auto;min-width:0}.certificate-user-email{font-size:14px;font-family:var(--mono);color:var(--text-2);max-width:min(320px,38vw);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.certificate-user-email[hidden]{display:none}.certificate-score-label{font-size:14px;font-family:var(--mono);font-weight:500;color:var(--text-2);white-space:nowrap}.certificate-score-pill{display:inline-flex;align-items:center;gap:6px;flex-shrink:0;white-space:nowrap;font-size:14px;font-weight:500;font-family:var(--mono);line-height:1;padding:5px 10px;border-radius:99px;border:1px solid transparent}.certificate-score-pill--red{color:#f87171;background:#f871711a;border-color:#f871714d}.certificate-score-pill--blue{color:var(--score-gold);background:var(--score-gold-dim);border-color:var(--score-gold-mid)}.certificate-score-pill--green{color:var(--green);background:#34d3991a;border-color:#34d3994d}.certificate-score-divider{width:1px;height:20px;flex-shrink:0;background:#ffffff24}.certificate-score-pct{font-size:14px;font-weight:600;font-family:var(--mono);white-space:nowrap;line-height:1}.certificate-score-pct--red{color:#f87171}.certificate-score-pct--blue{color:var(--score-gold)}.certificate-score-pct--green{color:var(--green)}.certificate-download-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;display:flex;align-items:center;justify-content:center;padding:24px}.certificate-download-modal[hidden]{display:none!important}.certificate-download-modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;background:#020812b8}.certificate-download-modal-panel{position:relative;z-index:1;width:min(100%,520px);padding:24px 26px 22px;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:linear-gradient(180deg,#111b2e,#0c1424);box-shadow:0 20px 48px #00000073;text-align:center}.certificate-download-modal-close{position:absolute;top:10px;right:10px;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:var(--r-xs);background:transparent;color:var(--text-3);font-size:18px;line-height:1;cursor:pointer;transition:color .15s ease,background .15s ease}.certificate-download-modal-close:hover{color:var(--text-1);background:#ffffff14}.certificate-download-modal-title{margin:0 0 12px;padding-right:28px;font-size:18px;font-weight:700;color:var(--text-1)}.certificate-download-modal-message{margin:0 0 20px;font-size:14px;line-height:1.55;color:var(--text-2)}.certificate-download-modal-actions{display:flex;flex-direction:column;gap:10px}.btn-certificate-download-confirm{display:inline-flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:4px;width:100%;min-height:40px;padding:8px 14px;font-size:14px;font-weight:600;color:var(--text-2);background:transparent;border:1px solid rgba(255,255,255,.14);border-radius:8px;cursor:pointer;text-align:center;transition:color .15s ease,border-color .15s ease,background .15s ease}.certificate-download-modal-actions:not(.is-high-score) .btn-certificate-download-confirm .certificate-score-pct{font-weight:700}.btn-certificate-download-confirm:hover{color:var(--text-1);border-color:#ffffff3d;background:#ffffff0a}.btn-certificate-download-later{display:inline-flex;align-items:center;justify-content:center;width:100%;min-height:40px;padding:8px 14px;font-size:14px;font-weight:700;color:#061a12;background:var(--green);border:1px solid transparent;border-radius:8px;cursor:pointer;text-align:center;transition:background .15s ease,box-shadow .15s ease}.btn-certificate-download-later:hover{background:#5eead4;box-shadow:0 0 16px #2dd4bf47}.certificate-download-modal-actions.is-high-score .btn-certificate-download-confirm{font-weight:700;color:#061a12;background:var(--green);border-color:transparent;transition:background .15s ease,box-shadow .15s ease}.certificate-download-modal-actions.is-high-score .btn-certificate-download-confirm .certificate-score-pct{color:#061a12}.certificate-download-modal-actions.is-high-score .btn-certificate-download-confirm:hover{color:#061a12;background:#5eead4;border-color:transparent;box-shadow:0 0 16px #2dd4bf47}.certificate-download-modal-actions.is-high-score .btn-certificate-download-later{font-weight:600;color:var(--text-2);background:transparent;border:1px solid rgba(255,255,255,.14);box-shadow:none;transition:color .15s ease,border-color .15s ease,background .15s ease}.certificate-download-modal-actions.is-high-score .btn-certificate-download-later:hover{color:var(--text-1);background:#ffffff0a;border-color:#ffffff3d;box-shadow:none}.btn-download-certificate-wrap{display:inline-flex}.btn-download-certificate-wrap[data-tooltip]{cursor:not-allowed}.btn-download-certificate-wrap[data-tooltip] .btn-download-certificate:disabled{pointer-events:none}.btn-download-certificate{display:inline-flex;align-items:center;gap:8px;flex-shrink:0;font-size:16px;font-weight:700;padding:0 16px;height:32px;background:var(--green);color:#061a12;border:1px solid transparent;cursor:pointer;transition:background .15s ease,box-shadow .15s ease,transform .12s ease}.btn-download-certificate:hover{background:#5eead4;box-shadow:0 0 16px #2dd4bf47}.btn-download-certificate:active{transform:scale(.97)}.btn-download-certificate:disabled{cursor:not-allowed;opacity:.42;box-shadow:none}.btn-download-certificate:disabled:hover{background:var(--green);box-shadow:none}#app.is-certificate-view .performance-mascot-wrap,#app.is-certificate-view .col-task,#app.is-certificate-view .col-resizer,#app.is-certificate-view .editor-pane,#app.is-certificate-view .editor-tabbar,#app.is-certificate-view .row-resizer,#app.is-certificate-view .output-pane,#app.is-certificate-view .task-col-floating-toggle,#app.is-project-overview-view .performance-mascot-wrap,#app.is-project-overview-view .col-task,#app.is-project-overview-view .col-resizer,#app.is-project-overview-view .row-resizer,#app.is-project-overview-view .output-pane,#app.is-project-overview-view .task-col-floating-toggle,#app.is-project-overview-view .approach-voice-pane{display:none!important}#app.is-project-overview-view .editor-pane,#app.is-project-overview-view.is-task-starting .editor-pane{display:flex!important;flex-direction:column;grid-template-rows:unset}.project-overview-pane{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;background:radial-gradient(ellipse 80% 50% at 50% -10%,rgba(45,212,191,.08),transparent 55%),linear-gradient(180deg,#0e1929,#111827);scrollbar-gutter:stable}.project-overview{max-width:820px;margin:0 auto;padding:36px 40px 56px}.project-overview-header{margin-bottom:32px;padding-bottom:28px;border-bottom:1px solid rgba(45,212,191,.12)}.project-overview-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;background:#2dd4bf1a;border:1px solid rgba(45,212,191,.22);color:#5eead4;font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;margin-bottom:16px}.project-overview-title{font-size:clamp(1.65rem,2.4vw,2.1rem);font-weight:700;line-height:1.25;color:var(--text-0);margin:0 0 10px;letter-spacing:-.02em}.project-overview-lead{margin:0;font-size:15px;line-height:1.65;color:var(--text-2);max-width:56ch}.project-overview-sections{display:flex;flex-direction:column;gap:20px}.project-overview-section{background:#0f1c33b8;border:1px solid rgba(74,103,133,.28);border-radius:14px;padding:22px 24px 24px;box-shadow:0 8px 28px #0000002e;animation:projectOverviewFadeIn .35s ease both;animation-delay:calc(var(--section-index, 0) * 70ms)}@keyframes projectOverviewFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.project-overview-section-head{display:flex;align-items:center;gap:14px;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid rgba(74,103,133,.22)}.project-overview-section-num{flex-shrink:0;width:30px;height:30px;display:grid;place-items:center;border-radius:9px;background:linear-gradient(135deg,#2dd4bf38,#60a5fa2e);border:1px solid rgba(45,212,191,.28);color:#99f6e4;font-size:13px;font-weight:700}.project-overview-section-title{margin:0;font-size:1.15rem;font-weight:600;color:#e2eaf5;letter-spacing:-.01em}.project-overview-section-body{color:#b8c9de;font-size:15px;line-height:1.72}.proj-md-h3{margin:18px 0 10px;font-size:1rem;font-weight:600;color:#dbeafe}.proj-md-h3:first-child{margin-top:0}.proj-md-h4{margin:14px 0 8px;font-size:.92rem;font-weight:600;color:#c4d4e8}.proj-md-p{margin:0 0 12px}.proj-md-p:last-child{margin-bottom:0}.proj-md-list{margin:0 0 14px;padding-left:1.25rem;display:flex;flex-direction:column;gap:8px}.proj-md-list li{position:relative}.proj-md-list li::marker{color:#2dd4bf}.proj-md strong{color:#f0f6fc;font-weight:600}.proj-md em{color:#cbd5e1;font-style:italic}.proj-md code{font-family:JetBrains Mono,Fira Code,monospace;font-size:.88em;padding:2px 6px;border-radius:5px;background:#0f172ad9;border:1px solid rgba(74,103,133,.35);color:#7dd3fc}.tree-file.is-project-overview-file .tree-file-label{color:#99f6e4}.col-editor-wrap.is-project-overview .editor-placeholder{display:none!important}.output-pane{height:var(--output-h);flex-shrink:0;display:flex;flex-direction:column;overflow:hidden;background:#070d18;border-top:1px solid rgba(0,0,0,.5)}.output-pane.is-minimized .output-body{display:none}.output-pane.is-minimized{border-top:none}.output-topbar{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;background:#070d18;border-bottom:none;padding:8px 12px}.output-pane.is-minimized .output-topbar{border-bottom:none;padding:8px 12px 12px}.output-tabs{display:flex;align-items:center;gap:2px}.output-tab{display:flex;align-items:center;gap:5px;font-size:14px;font-weight:500;font-family:var(--font);padding:5px 10px;border-radius:var(--r-xs);background:none;border:none;color:var(--text-3);cursor:pointer;transition:all .12s}.output-tab:hover{color:var(--text-2);background:#ffffff0d}.output-tab.active{color:var(--text-1);background:#ffffff14}.output-actions{display:flex;align-items:center;gap:6px}.btn-submit-wrap{display:inline-flex}.btn-submit-wrap[data-tooltip]{cursor:not-allowed}.btn-submit-wrap[data-tooltip] .btn-submit:disabled{pointer-events:none}.output-body.is-guidance-pane{padding:0;overflow:hidden;font-family:var(--font);font-size:14px;line-height:1.5}.output-body{flex:1;overflow-y:auto;padding:10px 14px;font-family:var(--mono);font-size:18px;line-height:1.7;background:#070d18;scrollbar-width:none;-ms-overflow-style:none}.output-body::-webkit-scrollbar{width:0;height:0}.terminal-pane{height:100%;min-height:0;display:flex;flex-direction:column}.output-run-header,.output-run-status,.output-runtime-setup,.output-preview-log-wrap{flex-shrink:0}.output-empty{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center}.output-empty-icon{width:40px;height:40px;color:var(--border-2);opacity:.7}.output-empty-text{font-size:15px;color:var(--text-3);font-family:var(--font);letter-spacing:.2px}.output-empty-text strong{color:#7a9bb8;font-weight:600}.help-pane{height:100%;overflow:hidden;background:linear-gradient(180deg,#070d18,#0a1220)}.guidance-chat-scroll{height:100%;min-height:0;overflow-y:auto;overflow-x:hidden;padding:16px 18px 18px;display:flex;flex-direction:column;gap:16px;scrollbar-gutter:stable}.guidance-chat-messages{display:flex;flex-direction:column;gap:14px;flex-shrink:0}.chat-row{display:flex;align-items:flex-end;gap:10px;width:fit-content;max-width:70%;animation:guidanceBubbleIn .28s ease both}@keyframes guidanceBubbleIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chat-row--system{align-self:flex-start;margin-right:auto}.chat-row--user{align-self:flex-end;flex-direction:row;margin-left:auto}.chat-avatar{flex-shrink:0;width:36px;height:36px;border-radius:50%;object-fit:cover}.chat-avatar-wrap--system{flex-shrink:0;width:36px;height:36px;border-radius:50%;overflow:hidden;background:#0f1c33;box-shadow:0 0 0 2px #2dd4bf33;display:grid;place-items:center}.chat-avatar--system{width:36px;height:36px;border:none;border-radius:0;box-shadow:none;background:transparent;object-fit:cover;object-position:center;transform:scale(1.28)}.chat-avatar--user{display:grid;place-items:center;background:#e2e8f029;border:none;box-shadow:none;color:#cbd5e1}.chat-bubble{flex:1;min-width:0;padding:11px 15px;border-radius:18px;line-height:1.55;font-size:14px;max-width:100%;border:none}.chat-bubble--system{background:#102a2ee0;border-bottom-left-radius:5px;color:#c8ebe4;box-shadow:none}.chat-bubble--user{background:linear-gradient(135deg,#f1f5f924,#e2e8f01a);border-bottom-right-radius:5px;color:#e2e8f0;box-shadow:none}.chat-bubble-text{margin:0;white-space:pre-wrap;word-break:break-word;overflow-wrap:anywhere}.chat-bubble-text code{font-family:var(--mono);font-size:.92em;line-height:inherit;vertical-align:baseline;padding:1px 5px;border-radius:3px;overflow-wrap:anywhere;word-break:normal;font-weight:500;border:none;box-shadow:none}.chat-bubble--system .chat-bubble-text code{color:#8ed9b8;background:#a0b9ac24}.chat-bubble--user .chat-bubble-text code{color:#a0e0c4;background:#a0b9ac1a}.chat-bubble-audio{margin-bottom:10px}.chat-inline-audio{gap:8px}.chat-inline-audio .help-audio-play{width:32px;height:32px}.chat-inline-audio .help-audio-times{font-size:11px}.chat-inline-audio .help-audio-seek{height:10px}.guidance-composer{flex-shrink:0;position:static;padding:4px 0 0;margin-top:4px;background:transparent;border:none}.guidance-composer-inner{margin-left:auto;width:100%;max-width:70%;display:grid;grid-template-columns:minmax(0,1fr) 44px;column-gap:10px;row-gap:10px}.guidance-composer-check-stack{grid-column:1 / -1;justify-self:end;display:flex;flex-direction:column;align-items:stretch;gap:10px;width:fit-content;max-width:100%}.guidance-composer-check-stack .guidance-composer-check-wrap{grid-column:auto;justify-self:auto;width:auto;max-width:none}.guidance-composer-check-stack .guidance-or-divider{grid-column:auto;width:100%;padding-inline:0}.guidance-composer-check-wrap{grid-column:1 / -1;justify-self:end;width:fit-content;max-width:100%}.guidance-quick-btn{grid-column:auto;justify-self:auto;width:fit-content;max-width:100%;height:32px;min-height:32px;padding:0 16px;font-size:16px;font-weight:700;line-height:1;text-align:center;white-space:nowrap;display:flex;justify-content:center;align-items:center;border-radius:var(--r-sm);color:#000;background:var(--teal);border:1px solid var(--teal);box-shadow:0 2px 10px #38bdf847;transition:background .16s ease,border-color .16s ease,box-shadow .16s ease}.guidance-quick-btn:hover:not(:disabled){color:#000;background:#7dd3fc;border-color:#7dd3fc;box-shadow:0 4px 14px #38bdf85c}.guidance-quick-btn:disabled{opacity:.45;cursor:not-allowed}.guidance-or-divider{grid-column:1 / -1;display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding-inline:25%;color:var(--text-3);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase}.guidance-or-divider:before,.guidance-or-divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,rgba(74,103,133,.45),transparent)}.guidance-compose-row{display:contents}.guidance-input-wrap{grid-column:1;align-self:center;flex:1;min-width:0;min-height:44px;position:relative;display:flex;align-items:center;gap:4px;background:#0f1c33f2;border:1px solid rgba(56,189,248,.55);border-radius:14px;padding:4px 4px 4px 8px;box-sizing:border-box;transition:border-color .15s ease,box-shadow .15s ease}.guidance-input-wrap:focus-within{border-color:#38bdf8b8;box-shadow:0 0 0 3px #60a5fa1a}.guidance-input-field{flex:1;min-width:0;position:relative;display:flex;align-items:center}.guidance-input-wrap.is-empty:not(:focus-within) .guidance-input-field:after{content:"";position:absolute;left:10px;top:50%;width:1px;height:1.15em;background:#38bdf8;border-radius:1px;pointer-events:none;transform:translateY(-50%);animation:guidanceCaretBlink 1s step-end infinite}@keyframes guidanceCaretBlink{0%,to{opacity:1}50%{opacity:0}}.guidance-input{display:block;width:100%;min-width:0;min-height:36px;max-height:calc(4.35em + 14px);padding:7px 10px;border:none;background:transparent;color:var(--text-1);font-family:var(--font);font-size:14px;line-height:1.45;box-sizing:border-box;resize:none;outline:none;caret-color:#38bdf8;caret-width:thin;overflow-y:auto;text-align:left;scrollbar-width:none;-ms-overflow-style:none}.guidance-input::-webkit-scrollbar{width:0;height:0}.guidance-input.is-scrolling{scrollbar-width:thin;scrollbar-color:rgba(74,103,133,.55) transparent}.guidance-input.is-scrolling::-webkit-scrollbar{width:5px}.guidance-input.is-scrolling::-webkit-scrollbar-thumb{background:#4a67858c;border-radius:99px}.guidance-input::placeholder{color:#6a8aaab8;text-align:left;line-height:1.45}.guidance-voice-btn{flex-shrink:0;width:36px;height:36px;display:grid;place-items:center;border:none;border-radius:10px;background:#38bdf81a;color:#7dd3fc;cursor:pointer;transition:background .15s ease,color .15s ease}.guidance-voice-btn:hover{background:#38bdf833;color:#bae6fd}.guidance-send-btn{grid-column:2;align-self:center;flex-shrink:0;width:44px;height:44px;min-height:44px;padding:0;display:flex;align-items:center;justify-content:center;border:1px solid rgba(56,189,248,.55);border-radius:14px;cursor:not-allowed}.guidance-send-btn svg{margin:0;display:block;flex-shrink:0}.guidance-send-btn.is-active{cursor:pointer}.guidance-send-btn:hover:not(:disabled){border-color:#38bdf8b8}.guidance-send-btn:disabled:not(.is-active){opacity:.45}.chat-row--typing .chat-bubble--system{padding:14px 18px}.chat-typing-dots{display:inline-flex;gap:5px;align-items:center}.chat-typing-dots span{width:6px;height:6px;border-radius:50%;background:#2dd4bfbf;animation:guidanceTypingDot 1.2s ease-in-out infinite}.chat-typing-dots span:nth-child(2){animation-delay:.15s}.chat-typing-dots span:nth-child(3){animation-delay:.3s}@keyframes guidanceTypingDot{0%,60%,to{transform:translateY(0);opacity:.45}30%{transform:translateY(-4px);opacity:1}}.out-line{display:flex;align-items:flex-start;gap:8px;padding:2px 0;color:var(--text-2);font-size:18px}.out-line.success{color:var(--green)}.out-line.error{color:var(--red)}.out-line.info{color:var(--blue)}.out-prompt{color:var(--text-3);flex-shrink:0}.output-run-header{align-items:center;gap:10px}.output-run-header-text{flex:1;min-width:0}.output-run-header-actions{margin-left:auto;display:inline-flex;align-items:center;gap:6px;flex-shrink:0}.output-run-header-btn{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:1px solid rgba(148,163,184,.22);border-radius:6px;background:#0f172ab8;color:#94a3b8;cursor:pointer;transition:color .15s ease,border-color .15s ease,background .15s ease}.output-run-header-btn:hover{color:#e2e8f0;border-color:#38bdf873;background:#0f172af2}.output-run-header-btn:focus-visible{outline:2px solid rgba(56,189,248,.55);outline-offset:2px}.output-run-popup-note{margin-top:4px;font-size:14px}.output-run-file{font-family:var(--mono);font-size:.92em;color:#cbd5e1}.output-syntax-ok{font-size:16px;line-height:1.55;padding:2px 0;white-space:pre-wrap;word-break:break-word}.output-terminal-log-wrap{margin-top:8px;display:flex;flex-direction:column;gap:4px}.output-preview-log-wrap{max-height:180px;overflow-y:auto;border-top:1px solid var(--border);padding-top:8px}.output-terminal-log{white-space:pre-wrap;word-break:break-word;font-family:var(--mono);font-size:16px;line-height:1.55;color:var(--text-2);padding:2px 0}.output-terminal-log.is-error,.output-terminal-log.is-warn{color:var(--red)}.output-terminal-log.is-info{color:var(--blue)}.output-run-error{white-space:pre-wrap;word-break:break-word;font-family:var(--mono);font-size:16px;line-height:1.55;color:var(--red);padding:8px 10px;margin-top:6px;border-radius:var(--r-xs);background:#ef444414;border:1px solid rgba(239,68,68,.22)}.output-runtime-setup{display:flex;align-items:flex-start;gap:10px;margin:10px 0 8px;padding:10px 12px;border-radius:var(--r-xs);background:#38bdf814;border:1px solid rgba(56,189,248,.18)}.output-runtime-spinner{width:16px;height:16px;margin-top:2px;border:2px solid rgba(125,211,252,.25);border-top-color:#38bdf8;border-radius:50%;flex-shrink:0;animation:outputRuntimeSpin .75s linear infinite}.output-runtime-setup-copy{display:flex;flex-direction:column;gap:4px;min-width:0}.output-runtime-setup-text{font-family:var(--font);font-size:14px;line-height:1.45;color:#e2e8f0}.output-runtime-setup-hint{font-family:var(--font);font-size:12px;line-height:1.4;color:#94a3b8}@keyframes outputRuntimeSpin{to{transform:rotate(360deg)}}.output-iframe-wrap{width:100%;flex:1 1 auto;min-height:200px;border-radius:var(--r-xs);overflow:hidden;border:1px solid var(--border)}.output-preview-stage{width:100%;flex:1 1 auto;min-height:0;margin-top:6px;display:flex;justify-content:stretch;align-items:stretch;overflow:hidden}.output-preview-stage.is-mobile-device{justify-content:center;align-items:center;padding:8px;border-radius:var(--r-xs);border:1px solid var(--border);background:radial-gradient(circle at 50% 0%,rgba(56,189,248,.08),transparent 42%),#0f172a59}.output-preview-stage.is-mobile-device .output-iframe-wrap{flex:0 0 auto;min-height:0;max-height:100%;border-radius:16px;overflow:hidden;box-shadow:0 0 0 1px #94a3b82e,0 14px 32px #00000059}.output-iframe-wrap iframe{width:100%;height:100%;border:none;background:#fff}.feedback-pane{font-family:var(--mono);font-size:14px;line-height:1.6;padding:4px 2px 12px}.feedback-audio-bar-wrap{margin:0 0 20px}.feedback-audio-bar{max-width:100%}.feedback-audio-bar .help-audio-track-wrap{min-width:0}.feedback-intro{margin:0 0 14px;color:#94a3b8;font-size:14px;line-height:1.65}.feedback-sections{display:flex;flex-direction:column;gap:18px}.feedback-section{border:1px solid rgba(56,189,248,.1);border-radius:var(--r-xs);background:#0f172a73;overflow:hidden}.feedback-section-hdr{width:100%;display:flex;align-items:center;gap:8px;padding:10px 12px;background:transparent;border:none;cursor:pointer;text-align:left;font-family:var(--mono);font-size:14px;line-height:1.5;min-width:0;transition:background .14s ease}.feedback-section-hdr:hover{background:#ffffff08}.feedback-chevron{flex-shrink:0;width:12px;height:12px;color:#64748b;transition:transform .2s ease,color .14s ease}.feedback-section.is-open .feedback-chevron{transform:rotate(90deg);color:#94a3b8}.feedback-heading{flex-shrink:0;color:#c084fc;font-weight:500}.feedback-score{flex-shrink:0;font-weight:500}.feedback-score--red{color:var(--red)}.feedback-score--blue{color:var(--score-gold)}.feedback-score--green{color:var(--green)}.feedback-colon{flex-shrink:0;color:#c084fc}.feedback-preview{flex:1;min-width:0;color:#94a3b8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.feedback-section.is-open .feedback-preview{display:none}.feedback-section-body{display:none;padding:0 12px 12px 32px;color:#b8cfe8;font-size:14px;line-height:1.65;white-space:pre-wrap;word-break:break-word}.feedback-section.is-open .feedback-section-body{display:block}.feedback-wrap{display:flex;flex-direction:column;gap:8px}.feedback-hdr{font-size:18px;font-weight:600;color:var(--teal);display:flex;align-items:center;gap:6px}.feedback-body{font-size:18px;line-height:1.6;color:var(--text-2);font-family:var(--font)}.resize-handle{width:4px;background:transparent;cursor:col-resize;transition:background .15s}.resize-handle:hover{background:var(--teal-mid)}@keyframes ws-skel-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.ws-skel{display:inline-block;border-radius:6px;background:linear-gradient(90deg,#1e3452f2,#304a6efa,#1e3452f2 84%);background-size:200% 100%;animation:ws-skel-shimmer 1.35s ease-in-out infinite;vertical-align:middle}.ws-skel-bar{max-width:100%}.ws-skel-num{width:24px;height:14px;flex-shrink:0}.ws-skel-chevron{width:16px;height:16px;border-radius:4px;flex-shrink:0;margin-left:auto}.ws-skel-chevron-sm{width:14px;height:14px;border-radius:4px;flex-shrink:0}.ws-skel-file-icon{width:14px;height:14px;border-radius:3px;flex-shrink:0}.ws-skel-btn-icon{border-radius:50%}#app.is-workspace-loading{pointer-events:none;-webkit-user-select:none;user-select:none}#app.is-workspace-loading .hdr-progress-pct,#app.is-workspace-loading .task-file-chip .chip-label{visibility:hidden}.ws-skel-tree-file{pointer-events:none;display:flex;align-items:center;gap:7px;padding:5px 14px 5px 22px;margin:1px 5px}.ws-skel-index{pointer-events:none}.ws-skel-index-section{list-style:none;border-radius:var(--r-sm);border:1px solid rgba(56,189,248,.14);background:linear-gradient(180deg,#1a3354,#142a46);overflow:hidden}.ws-skel-index-hdr{display:flex;align-items:center;gap:10px;padding:14px 12px 10px 16px}.ws-skel-subtask-card{pointer-events:none}.ws-skel-card-hdr{display:flex;align-items:flex-start;gap:8px;padding:14px 16px 10px;cursor:default}.ws-skel-card-body{display:flex;flex-direction:column;gap:10px;padding:0 16px 16px}.ws-skel-perf-empty{display:flex;justify-content:center;padding:16px 14px 20px;margin:0}.ws-skel-tab{display:inline-flex;align-items:center;min-width:96px;min-height:32px;padding:6px 14px;border-radius:var(--r-xs) var(--r-xs) 0 0;background:var(--bg-tabbar);border:1px solid var(--border);border-bottom:none}#app.is-workspace-loading .monaco-editor-host{background:var(--bg-editor)}.workspace-editor-skeleton{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;display:flex;background:var(--bg-editor);pointer-events:none}.workspace-editor-skeleton-gutter{width:48px;flex-shrink:0;border-right:1px solid var(--border);background:#0e1929}.workspace-editor-skeleton-lines{flex:1;display:flex;flex-direction:column;gap:12px;padding:18px 20px}.workspace-editor-skeleton-lines .ws-skel-bar{height:11px;display:block}.workspace-loader{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;background:#07101eeb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.workspace-loader[hidden]{display:none}.workspace-loader-text{margin:0;font-size:15px;color:var(--text-2)}.workspace-loader.is-error .workspace-loader-text{color:#f87171;max-width:420px;text-align:center;line-height:1.5;padding:0 24px}.feedback-view-submitted-wrap{margin-top:20px}.btn-view-submitted{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;padding:0 16px;height:34px;background:var(--teal-dim);border:1px solid var(--border-teal);color:var(--teal);border-radius:999px;cursor:pointer;transition:background .15s,border-color .15s,box-shadow .15s}.btn-view-submitted:hover{background:var(--teal-mid);border-color:var(--teal);box-shadow:0 0 12px #38bdf826}#app.is-submitted-view .hdr-progress-wrap,#app.is-submitted-view .btn-hamburger,#app.is-submitted-view .task-panel-overlay,#app.is-submitted-view .task-panel,#app.is-submitted-view .col-explorer,#app.is-submitted-view .btn-save,#app.is-run-output-unavailable #btn-run-wrap,#app.is-run-output-unavailable .output-tab[data-pane=terminal],#app.is-run-output-unavailable #output-empty,#app.is-submitted-view .btn-run,#app.is-submitted-view .output-tab[data-pane=terminal],#app.is-submitted-view .task-col-help-toggle,#app.is-submitted-view .task-help-bar,#app.is-submitted-view .feedback-view-submitted-wrap{display:none!important}#app.is-submitted-view .editor-tabbar{display:flex}#app.is-submitted-view .output-tab[data-pane=feedback]{pointer-events:none;cursor:default}#app.is-submitted-view .output-tab[data-pane=feedback].active{color:var(--text-1)}#app.is-submitted-view .btn-submit.is-submitted:disabled{opacity:.42;cursor:not-allowed;pointer-events:none}#app.is-submitted-view .card-hdr[onclick],#app.is-submitted-view .feedback-section-hdr,#app.is-submitted-view .task-col-eye-toggle,#app.is-submitted-view .col-resizer,#app.is-submitted-view .row-resizer{pointer-events:auto}#app.is-submitted-view .app-header *,#app.is-submitted-view .output-actions .btn-submit,#app.is-submitted-view .editor-tab,#app.is-submitted-view .card-back,#app.is-submitted-view .help-step-row,#app.is-submitted-view .tp-index,#app.is-submitted-view .tree-folder,#app.is-submitted-view .submitted-drawer-hdr{pointer-events:none;cursor:default}#app.is-submitted-view .monaco-editor,#app.is-submitted-view .monaco-editor *{pointer-events:auto}:root{--shell-bg: #07101e;--shell-panel: #0c1627;--shell-card: #0f1d33;--shell-border: rgba(56, 189, 248, .18);--shell-text: #edf2fb;--shell-muted: #94a3b8;--shell-teal: #38bdf8;--shell-green: #34d399;--shell-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace}body.is-shell{margin:0;min-height:100vh;background:radial-gradient(ellipse 80% 50% at 50% -10%,rgba(56,189,248,.08) 0%,transparent 60%),linear-gradient(180deg,#0a1424 0%,var(--shell-bg) 100%);color:var(--shell-text);font-family:Inter,system-ui,sans-serif}body.is-shell:has(.subjects-page){height:100vh;overflow:hidden}body.is-workspace{margin:0;overflow:hidden;height:100%;width:100%}body.is-workspace #app-root{height:100%;overflow:hidden}body.is-shell #app-root{min-height:100vh}body.is-shell:has(.subjects-page) #app-root{height:100%;min-height:0}.shell-page{min-height:100vh}.subjects-page{display:flex;flex-direction:column;height:100%;min-height:0;overflow:hidden}.subjects-page .shell-topbar{flex-shrink:0;position:static}.subjects-page .shell-main{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;scrollbar-width:none;-ms-overflow-style:none}html:has(.subjects-page),body.is-shell:has(.subjects-page){scrollbar-width:none;-ms-overflow-style:none}.subjects-page .shell-main::-webkit-scrollbar,html:has(.subjects-page)::-webkit-scrollbar,body.is-shell:has(.subjects-page)::-webkit-scrollbar{display:none;width:0;height:0}.login-page{display:flex;flex-direction:column;min-height:100vh}.login-page .shell-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;max-width:min(960px,96vw);margin:0 auto;padding:28px 24px 56px;width:100%;box-sizing:border-box}.login-page .login-hero.subjects-hero{max-width:none;width:100%;margin-bottom:32px;padding-left:0;padding-right:0}.login-page .subjects-heading{font-size:clamp(1.5rem,2.8vw,2.25rem);white-space:nowrap}.login-page .subjects-lead{font-size:clamp(13px,1.35vw,15px);white-space:nowrap}@media (max-width: 920px){.login-page .subjects-heading,.login-page .subjects-lead{white-space:normal}}.login-panel{position:relative;width:100%;max-width:440px;box-sizing:border-box;padding:28px 26px 26px;background:linear-gradient(180deg,#1a2a42,#152238 38%,#111c2e 72%,#0c1424);border:1px solid #3d4f66;border-top-color:#526480;border-bottom-color:#283548;border-radius:12px;box-shadow:0 0 0 1px #0f172aa6,inset 0 1px #64748b33,inset 0 -2px 6px #02061780,0 2px #080e1ae6,0 6px 14px #0006,0 14px 28px #0000004d}.login-panel:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;background:linear-gradient(165deg,rgba(30,41,59,.35) 0%,transparent 42%,rgba(2,6,23,.25) 100%)}.login-panel>*{position:relative;z-index:1}.login-form{display:flex;flex-direction:column;gap:0}.login-field-label{display:block;margin:0 0 10px;font-size:13px;font-weight:600;letter-spacing:.02em;color:var(--shell-muted)}.login-field-wrap{margin-bottom:18px}.login-field-wrap.is-invalid .login-email-input,.login-field-wrap.is-invalid .login-password-input{border-color:#f87171a6;box-shadow:0 0 0 3px #f871711f}.login-field-icon{left:14px}.login-email-input,.login-password-input{padding-left:44px}.login-submit-btn{position:relative;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;height:44px;margin-top:4px;padding:0 20px;border-radius:10px;font-family:inherit;font-size:16px;font-weight:700;cursor:pointer;border:1px solid rgba(125,211,252,.55);background:linear-gradient(180deg,#4da8ff,#2b8ef0 48%,#1a75db);color:#f0f9ff;box-shadow:inset 0 1px #ffffff38,0 2px 8px #2589f066;text-shadow:0 1px 0 rgba(15,60,120,.35);transition:background .15s ease,border-color .15s ease,box-shadow .15s ease,transform .15s ease}.login-submit-btn:after{content:"";position:absolute;top:0;left:0;width:55%;height:100%;background:linear-gradient(105deg,transparent 12%,rgba(255,255,255,.5) 48%,rgba(255,255,255,.15) 58%,transparent 88%);transform:translate(-150%) skew(-22deg);animation:login-submit-shine 2.6s ease-in-out infinite;pointer-events:none}.login-submit-btn>*{position:relative;z-index:1}.login-submit-arrow{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;margin-left:2px;animation:login-submit-arrow-nudge 1.15s ease-in-out infinite}.login-submit-arrow svg{display:block}@keyframes login-submit-arrow-nudge{0%,to{transform:translate(-4px)}50%{transform:translate(5px)}}.login-submit-btn:disabled:not(.is-action-loading) .login-submit-arrow{animation-play-state:paused}@keyframes login-submit-shine{0%{transform:translate(-150%) skew(-22deg)}38%{transform:translate(350%) skew(-22deg)}to{transform:translate(350%) skew(-22deg)}}.login-submit-btn:hover:not(:disabled){background:linear-gradient(180deg,#6bb8ff,#3d9ef5 48%,#2280e0);color:#fff;border-color:#bae6fdbf;box-shadow:inset 0 1px #ffffff47,0 0 16px #38a3f873}.login-submit-btn:active:not(:disabled){transform:scale(.98);background:linear-gradient(180deg,#2b8ef0,#1a75db 52%,#145fad);box-shadow:inset 0 2px 4px #081e4666,0 1px 4px #2589f04d}.login-submit-btn:disabled:not(.is-action-loading){opacity:.48;cursor:not-allowed;pointer-events:none}.login-submit-btn:disabled:not(.is-action-loading):after{animation-play-state:running}.login-submit-btn:disabled.is-action-loading,.login-submit-btn.is-action-loading:disabled{opacity:.92;cursor:wait}.login-submit-btn:disabled.is-action-loading:after,.login-submit-btn.is-action-loading:disabled:after{animation-play-state:paused}.login-submit-btn.is-loading:hover,.login-submit-btn.is-action-loading:hover{transform:none;box-shadow:inset 0 1px #ffffff38,0 2px 8px #2589f066}.login-reset-password{display:block;width:100%;margin:14px 0 0;padding:0;border:none;background:none;font-family:inherit;font-size:14px;font-weight:600;line-height:1.4;color:#00c1ff;text-decoration:underline;text-underline-offset:3px;cursor:pointer;transition:color .15s ease,opacity .15s ease}.login-reset-password:hover:not(:disabled){color:#7dd3fc}.login-reset-password:disabled{opacity:.55;cursor:wait;text-decoration:none}.login-form-signin{display:flex;flex-direction:column}.login-form-signin[hidden]{display:none}.login-reset-success{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;margin-top:8px;padding:8px 4px 4px}.login-reset-success[hidden]{display:none}.login-reset-success-icon{display:flex;align-items:center;justify-content:center;width:88px;height:88px;border-radius:50%;background:#2589f024;color:#7dd3fc;margin-bottom:8px;box-shadow:inset 0 1px #ffffff1f,0 4px 20px #2589f033}.login-reset-success-title{margin:0;font-size:18px;font-weight:700;line-height:1.45;color:#edf2fb;max-width:22rem}.login-reset-success-subtitle{margin:0;font-size:14px;font-weight:500;line-height:1.55;color:#94a3b8f2;max-width:20rem}.login-form.is-reset-sent .login-field-label[for=login-email],.login-form.is-reset-sent .login-field-label[for=login-password],.login-form.is-reset-sent .login-field-wrap,.login-form.is-reset-sent #login-password-wrap,.login-form.is-reset-sent .login-error{display:none}.login-submit-spinner{width:16px;height:16px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:topic-card-enroll-spin .65s linear infinite;flex-shrink:0}.shell-logo{height:36px;width:auto;display:block;margin:0 auto 24px}.shell-logo-sm{height:42px;width:auto}.shell-title{margin:0 0 8px;font-size:24px;font-weight:700;text-align:center}.shell-subtitle,.shell-lead{margin:0 0 24px;font-size:14px;line-height:1.6;color:var(--shell-muted);text-align:center}.shell-lead{text-align:left;max-width:720px}.shell-label{display:block;margin-bottom:8px;font-size:13px;font-weight:500;color:var(--shell-muted)}.shell-input{width:100%;box-sizing:border-box;padding:12px 14px;margin-bottom:16px;background:#0f1d33e6;border:1px solid rgba(56,189,248,.22);border-radius:10px;color:var(--shell-text);font-size:15px;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s}.shell-input:focus{border-color:#38bdf88c;box-shadow:0 0 0 3px #38bdf81f}.login-error{margin:-6px 0 14px;font-size:13px;line-height:1.45;color:#fca5a5}.login-email-error{margin:-10px 0 10px}.login-error[hidden]{display:none}.shell-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;border-radius:10px;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;border:1px solid transparent;transition:all .16s ease}.shell-btn:disabled{opacity:.45;cursor:not-allowed}.shell-btn-primary{width:100%;background:#38bdf838;border-color:#38bdf88c;color:#38bdf8;box-shadow:0 2px 10px #38bdf826}.shell-btn-primary:hover:not(:disabled){background:#38bdf857;border-color:#38bdf8d9;color:#7dd3fc}.shell-btn-secondary{background:#ffffff0a;border-color:#ffffff1f;color:#b8cfe8}.shell-btn-secondary:hover{background:#38bdf81a;border-color:#38bdf859;color:#e0f2fe}.shell-topbar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:18px 24px;border-bottom:1px solid rgba(255,255,255,.06);background:#07101ed9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:sticky;top:0;z-index:10}.shell-topbar .shell-logo-sm{grid-column:2;justify-self:center}.shell-topbar-right{grid-column:3;justify-self:end}.shell-user-email{font-size:13px;color:var(--shell-muted);font-family:JetBrains Mono,monospace}.shell-main{max-width:1200px;margin:0 auto;padding:32px 24px 48px}.shell-heading{margin:0 0 10px;font-size:28px;font-weight:700}.subjects-hero{text-align:center;max-width:640px;margin:0 auto 36px;padding:8px 12px 0}#projects-view{width:80vw;margin-left:auto;margin-right:auto;box-sizing:border-box}#projects-view .subjects-hero{width:100%;max-width:none;margin:0 0 36px;padding:8px 0 0;text-align:left;box-sizing:border-box}#projects-view .subjects-hero>.subjects-eyebrow{text-align:center}#projects-view .projects-page-header{position:relative;display:flex;align-items:center;justify-content:center;width:100%;min-height:1.15em;margin:0;padding:0;box-sizing:border-box}#projects-view .projects-page-header .catalog-back-btn{position:absolute;left:0;top:50%;transform:translateY(-50%);display:inline-flex;align-items:center;justify-content:center;width:1.15em;height:1.15em;font-size:clamp(1.75rem,4vw,2.25rem);line-height:1;padding:0}#projects-view .projects-page-header .catalog-back-btn svg{display:block;width:100%;height:100%}#projects-view .projects-heading{width:100%;margin:0;padding:0 1.5em;text-align:center;font-size:clamp(1.75rem,4vw,2.25rem);line-height:1.25;box-sizing:border-box}.subjects-eyebrow{margin:0 0 10px;font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--shell-teal)}.subjects-heading{margin:0 0 12px;font-size:clamp(1.75rem,4vw,2.25rem);font-weight:700;line-height:1.15;background:linear-gradient(135deg,#fff,#bae6fd 40%,#38bdf8);-webkit-background-clip:text;background-clip:text;color:transparent}.subjects-lead{margin:0;font-size:15px;line-height:1.65;color:var(--shell-muted)}.subjects-page .shell-main{max-width:min(1600px,100%);padding:28px 48px 48px}.subjects-search-wrap{max-width:520px;margin:0 auto 28px}.subjects-search-field{position:relative;display:flex;align-items:center}.subjects-search-icon{position:absolute;left:14px;flex-shrink:0;color:var(--shell-muted);pointer-events:none}.subjects-search-input{width:100%;box-sizing:border-box;padding:12px 44px 12px 42px;background:#0f1d33eb;border:1px solid rgba(71,85,105,.45);border-radius:12px;color:var(--shell-text);font-size:15px;font-family:inherit;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.subjects-search-input::placeholder{color:#94a3b8bf}.subjects-search-input:focus{border-color:#38bdf880;box-shadow:0 0 0 3px #38bdf81a}.subjects-search-clear{position:absolute;right:8px;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;border-radius:8px;background:transparent;color:var(--shell-muted);cursor:pointer;transition:color .14s ease,background .14s ease}.subjects-search-clear:hover{color:var(--shell-text);background:#94a3b81f}.subjects-search-clear[hidden]{display:none}.card-grid.subject-card-grid{grid-template-columns:repeat(4,minmax(0,1fr));grid-auto-rows:1fr;align-items:stretch;gap:18px}#subjects-view .subject-card-grid .topic-card{min-height:84px;padding:22px 20px;align-items:center}#projects-view .project-card-grid{display:grid;grid-template-columns:minmax(0,1fr);grid-auto-rows:auto;align-items:stretch;gap:18px;width:100%;padding:0;box-sizing:border-box}#projects-view .project-card-grid .topic-card{width:100%;max-width:none;box-sizing:border-box}#projects-view .topic-card:not(.is-enrolled){cursor:default}#projects-view .topic-card:not(.is-enrolled):hover{transform:none;border-color:#38bdf880;border-top-color:var(--shell-teal);border-bottom-color:#38bdf861;box-shadow:0 0 0 1px #38bdf838,inset 0 1px #38bdf81f,inset 0 -2px 6px #02061780,0 2px #080e1ae6,0 6px 14px #0006,0 14px 28px #0000004d}#projects-view .topic-card:not(.is-enrolled):active{transform:none;box-shadow:0 0 0 1px #0f172aa6,inset 0 1px #64748b33,inset 0 -2px 6px #02061780,0 2px #080e1ae6,0 6px 14px #0006,0 14px 28px #0000004d}#projects-view .topic-card.is-enrolled{cursor:pointer}.catalog-back-btn{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;padding:0;background:transparent;border:none;color:var(--shell-text);cursor:pointer;transition:opacity .16s ease,color .16s ease}.catalog-back-btn svg{display:block;width:28px;height:28px}.catalog-back-btn:hover{opacity:.75;color:var(--shell-teal)}.shell-back-btn{display:inline-flex;align-items:center;gap:6px;margin-bottom:20px;padding:8px 12px;background:transparent;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--shell-muted);font-size:13px;font-family:inherit;cursor:pointer;transition:all .14s}.shell-back-btn:hover{color:var(--shell-text);border-color:#38bdf859;background:#38bdf814}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.topic-card{position:relative;display:flex;flex-direction:row;align-items:center;gap:14px;box-sizing:border-box;padding:18px 20px;text-decoration:none;color:inherit;background:linear-gradient(180deg,#1a2a42,#152238 38%,#111c2e 72%,#0c1424);border:1px solid #3d4f66;border-top-color:#526480;border-bottom-color:#283548;border-radius:12px;box-shadow:0 0 0 1px #0f172aa6,inset 0 1px #64748b33,inset 0 -2px 6px #02061780,0 2px #080e1ae6,0 6px 14px #0006,0 14px 28px #0000004d;min-height:0;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.topic-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(165deg,rgba(30,41,59,.35) 0%,transparent 42%,rgba(2,6,23,.25) 100%);pointer-events:none}.topic-card>*{position:relative;z-index:1}.topic-card:hover{transform:translateY(-3px);border-color:#38bdf880;border-top-color:var(--shell-teal);border-bottom-color:#38bdf861;box-shadow:0 0 0 1px #38bdf838,inset 0 1px #38bdf81f,inset 0 -2px 6px #0206177a,0 3px #080e1ad9,0 10px 20px #00000070,0 20px 36px #00000057}.topic-card:active{transform:translateY(-1px);box-shadow:inset 0 2px 4px #020617a6,inset 0 1px #33415526,0 2px 8px #00000059}.topic-card:focus-visible{outline:2px solid var(--shell-teal);outline-offset:3px}.topic-card-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#94a3b8;transition:color .16s ease}.topic-card:hover .topic-card-icon{color:var(--shell-teal)}.topic-card-icon-svg{display:block;width:24px;height:24px}.topic-card-body{display:flex;flex-direction:column;flex:1;min-width:0}#projects-view .topic-card-action{display:flex;align-items:center;justify-content:center;flex-shrink:0}#projects-view .topic-card-action--pending{width:48px;height:48px}#projects-view .topic-card-enroll-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;width:auto;min-width:0;height:32px;padding:0 16px;border-radius:10px;font-family:inherit;font-size:16px;font-weight:700;white-space:nowrap;cursor:pointer;border:1px solid rgba(125,211,252,.55);background:linear-gradient(180deg,#4da8ff,#2b8ef0 48%,#1a75db);color:#f0f9ff;box-shadow:inset 0 1px #ffffff38,0 2px 8px #2589f066;text-shadow:0 1px 0 rgba(15,60,120,.35);transition:all .15s ease}#projects-view .topic-card-enroll-btn:hover:not(:disabled){background:linear-gradient(180deg,#6bb8ff,#3d9ef5 48%,#2280e0);color:#fff;border-color:#bae6fdbf;box-shadow:inset 0 1px #ffffff47,0 0 16px #38a3f873;transform:none}#projects-view .topic-card-enroll-btn:active:not(:disabled){transform:scale(.97);background:linear-gradient(180deg,#2b8ef0,#1a75db 52%,#145fad);box-shadow:inset 0 2px 4px #081e4666,0 1px 4px #2589f04d}#projects-view .topic-card-enroll-btn.is-loading,#projects-view .topic-card-enroll-btn.is-action-loading{opacity:.92;cursor:wait;pointer-events:none}#projects-view .topic-card-enroll-btn.is-loading:hover,#projects-view .topic-card-enroll-btn.is-action-loading:hover{transform:none;box-shadow:inset 0 1px #ffffff38,0 2px 8px #2589f066}#projects-view .topic-card-enroll-spinner{width:14px;height:14px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:topic-card-enroll-spin .65s linear infinite;flex-shrink:0}@keyframes topic-card-enroll-spin{to{transform:rotate(360deg)}}#projects-view .topic-card.is-enrolling,#projects-view .topic-card.is-enrolling .topic-card-enroll-btn{pointer-events:none}#projects-view .topic-card-enroll-btn:disabled:not(.is-loading):not(.is-action-loading){opacity:.42;cursor:not-allowed;box-shadow:none}#projects-view .topic-card-enroll-btn:disabled:not(.is-loading):not(.is-action-loading):hover{background:linear-gradient(180deg,#4da8ff,#2b8ef0 48%,#1a75db);box-shadow:none}#projects-view .topic-card-completed-tag{display:inline-flex;align-items:center;justify-content:center;min-width:76px;padding:8px 14px;border-radius:10px;font-size:13px;font-weight:600;font-family:inherit;white-space:nowrap;cursor:default;-webkit-user-select:none;user-select:none;background:#ffffff0a;border:1px solid rgba(255,255,255,.12);color:#b8cfe8;box-shadow:none}#projects-view .topic-card-progress{position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0;width:48px;height:48px}#projects-view .topic-card-progress-ring{display:block}#projects-view .topic-card-ring-bg{fill:none;stroke:#ffffff0f;stroke-width:3}#projects-view .topic-card-ring-fill{fill:none;stroke:var(--shell-green);stroke-width:3;stroke-linecap:round;transition:stroke-dashoffset .5s ease}#projects-view .topic-card-progress-pct{position:absolute;font-size:14px;font-weight:500;font-family:var(--shell-mono);color:var(--shell-green);line-height:1;letter-spacing:-.3px}.topic-card-arrow{display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#64748b;transition:transform .18s ease,color .16s ease}.topic-card-arrow svg{display:block;width:22px;height:22px;stroke-linecap:round;stroke-linejoin:round}.topic-card-arrow svg polyline{stroke-linecap:round;stroke-linejoin:round}.topic-card:hover .topic-card-arrow{transform:translate(3px);color:var(--shell-teal)}.topic-card-title{margin:0;font-size:17px;font-weight:500;line-height:1.35;color:#e2e8f0;letter-spacing:-.01em;word-break:break-word}.topic-card-meta{display:inline-block;align-self:flex-start;width:fit-content;max-width:100%;margin-top:12px;padding:0 1.5ch;border:none;border-radius:8px;font-family:var(--shell-mono);font-size:13px;font-weight:500;line-height:1.65;letter-spacing:-.02em;color:#a8c4dc;background-color:#38bdf824}.shell-status{grid-column:1 / -1;margin:0;font-size:14px;color:var(--shell-muted);text-align:center;padding:24px 0}.shell-status-error{color:#f87171}.app-loading-status{display:inline-flex;align-items:center;justify-content:center;gap:10px}.app-loading-spinner{width:16px;height:16px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:app-loading-spin .65s linear infinite;flex-shrink:0;opacity:.85}.app-loading-text{line-height:1.4}@keyframes app-loading-spin{to{transform:rotate(360deg)}}.shell-status-loading{display:flex;align-items:center;justify-content:center}.workspace-loader .app-loading-status{color:var(--text-2);font-size:15px}.workspace-loader.is-error .app-loading-text{color:#f87171}#app.is-action-busy,body.is-action-busy,#app.is-action-busy *,#app.is-action-busy .is-action-loading,body.is-action-busy .is-action-loading{cursor:wait!important}.ws-action-btn.is-action-locked,.btn.is-action-locked,.approach-send-btn.is-action-locked,.guidance-quick-btn.is-action-locked,.topic-card-enroll-btn.is-action-locked{pointer-events:none!important;opacity:.5}.btn.is-action-loading,.guidance-send-btn.is-action-loading,.topic-card-enroll-btn.is-action-loading,.login-submit-btn.is-action-loading{display:inline-flex;align-items:center;justify-content:center;gap:7px;cursor:wait!important;pointer-events:none;opacity:.92}.btn.is-action-loading:disabled,.guidance-send-btn.is-action-loading:disabled,.topic-card-enroll-btn.is-action-loading:disabled,.login-submit-btn.is-action-loading:disabled{opacity:.92}.guidance-quick-btn.is-action-loading,.guidance-quick-btn.is-action-loading:disabled{opacity:.45}.approach-send-btn.is-action-loading,.approach-send-btn.is-action-loading:disabled{opacity:.42;filter:none}.ws-action-spinner{width:12px;height:12px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:ws-action-spin .65s linear infinite;flex-shrink:0}@keyframes ws-action-spin{to{transform:rotate(360deg)}}
