:root{--ink: #1b1a17;--board: #fbfaf6;--goblin: #2f8f5b;--goblin-deep: #246b45;--goblin-soft: #e7f1ea;--marker: #f2b705;--marker-soft: #fbeec2;--slate: #5c6670;--flag: #d1495b;--flag-soft: #f7dde1;--surface: #ffffff;--surface-sunk: #f6f4ee;--line: #e7e3d8;--line-strong: #d9d4c5;--ink-soft: #494742;--font-display: "Bricolage Grotesque", "Hanken Grotesque", system-ui, sans-serif;--font-body: "Hanken Grotesque", system-ui, -apple-system, sans-serif;--font-mono: "Space Mono", ui-monospace, "SF Mono", Menlo, monospace;--radius-sm: 8px;--radius: 14px;--radius-lg: 22px;--shadow-sm: 0 1px 2px rgba(27, 26, 23, .06), 0 1px 3px rgba(27, 26, 23, .05);--shadow: 0 6px 22px rgba(27, 26, 23, .08);--shadow-lg: 0 18px 50px rgba(27, 26, 23, .14);--maxw: 1080px}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font-body);background-color:var(--board);background-image:radial-gradient(rgba(92,102,112,.06) 1px,transparent 1px);background-size:22px 22px;color:var(--ink);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.08;letter-spacing:-.01em;margin:0}p{margin:0}button,input,textarea{font:inherit;color:inherit}a{color:var(--goblin-deep);text-decoration-thickness:1.5px;text-underline-offset:2px}:focus-visible{outline:2.5px solid var(--goblin);outline-offset:2px;border-radius:4px}.app-shell{min-height:100%;display:flex;flex-direction:column}.page{width:100%;max-width:var(--maxw);margin:0 auto;padding:28px 24px 64px;flex:1}.page--narrow{max-width:680px}.stack{display:flex;flex-direction:column;gap:16px}.row{display:flex;align-items:center;gap:12px}.spacer{flex:1}.muted{color:var(--slate)}.display{font-family:var(--font-display);font-weight:800;letter-spacing:-.03em}.eyebrow{font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--goblin-deep)}.state-center{display:grid;justify-items:center;gap:12px;text-align:center;padding:56px 24px;color:var(--slate)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}.stamp--press{animation:none}}.topbar{width:100%;max-width:var(--maxw);margin:0 auto;padding:18px 24px 0;display:flex;align-items:center;gap:14px}.wordmark{font-family:var(--font-display);font-weight:800;font-size:22px;letter-spacing:-.03em;color:var(--ink);text-decoration:none;display:inline-flex;align-items:baseline}.wordmark:hover{color:var(--ink)}.wordmark .dot{color:var(--goblin)}.btn{--btn-bg: var(--surface);--btn-fg: var(--ink);--btn-bd: var(--line-strong);-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1.5px solid var(--btn-bd);background:var(--btn-bg);color:var(--btn-fg);padding:11px 18px;border-radius:999px;font-weight:600;font-size:15px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:transform .08s ease,box-shadow .15s ease,background .15s ease,border-color .15s ease;text-decoration:none;white-space:nowrap}.btn:hover{box-shadow:var(--shadow-sm)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.btn--primary{--btn-bg: var(--goblin);--btn-fg: #fff;--btn-bd: var(--goblin)}.btn--primary:hover{--btn-bg: var(--goblin-deep)}.btn--ghost{--btn-bg: transparent;--btn-bd: transparent;padding-inline:12px}.btn--ghost:hover{--btn-bg: var(--surface-sunk)}.btn--danger-quiet{--btn-bd: transparent;--btn-bg: transparent;color:var(--slate);padding:6px;border-radius:8px}.btn--danger-quiet:hover{color:var(--flag);--btn-bg: var(--flag-soft)}.btn--lg{padding:15px 26px;font-size:17px}.field{display:flex;flex-direction:column;gap:7px}.label{font-size:13px;font-weight:600;letter-spacing:.02em;text-transform:uppercase;color:var(--slate)}.input{width:100%;background:var(--surface);border:1.5px solid var(--line-strong);border-radius:var(--radius-sm);padding:12px 14px;font-size:16px;transition:border-color .15s ease,box-shadow .15s ease}.input:focus{outline:none;border-color:var(--goblin);box-shadow:0 0 0 3px var(--goblin-soft)}.input--mono{font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase}.input--points{width:72px;text-align:center;font-family:var(--font-mono);padding-inline:6px}.select{border:1.5px solid var(--line-strong);background:var(--surface);border-radius:999px;padding:8px 14px;font-weight:600;font-size:14px;cursor:pointer}.chip{display:inline-flex;align-items:center;gap:7px;padding:5px 11px;border-radius:999px;background:var(--surface-sunk);border:1.5px solid var(--line);font-size:13px;font-weight:600;color:var(--ink-soft)}.code-pill{font-family:var(--font-mono);font-weight:700;letter-spacing:.16em}.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:12.5px;font-weight:600;border:1.5px solid transparent;white-space:nowrap}.pill .pip{width:7px;height:7px;border-radius:50%;background:currentColor}.pill--idle{color:var(--slate);background:var(--surface-sunk);border-color:var(--line)}.pill--working{color:var(--goblin-deep);background:var(--goblin-soft);border-color:#cfe4d8}.pill--grading{color:#9a7400;background:var(--marker-soft);border-color:#efdca0}.pill--graded{color:var(--goblin-deep);background:var(--goblin-soft);border-color:#cfe4d8}.pill--error{color:var(--flag);background:var(--flag-soft);border-color:#efc8ce}.banner{border-radius:var(--radius);padding:12px 15px;font-size:14.5px;border:1.5px solid transparent}.banner--error{color:var(--flag);background:var(--flag-soft);border-color:#efc8ce}.card{background:var(--surface);border:1.5px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card--pad{padding:24px}.stamp{--stamp-ink: var(--goblin);display:inline-grid;place-items:center;text-align:center;border:3px solid var(--stamp-ink);color:var(--stamp-ink);border-radius:14px;padding:10px 16px;transform:rotate(-6deg);background:#ffffff8c;box-shadow:inset 0 0 0 2px #fff9}.stamp--strong{--stamp-ink: var(--goblin)}.stamp--ok{--stamp-ink: #c69200}.stamp--weak{--stamp-ink: var(--flag)}.stamp__score{font-family:var(--font-mono);font-weight:700;font-size:30px;line-height:1;letter-spacing:-.02em}.stamp__pct{font-family:var(--font-mono);font-size:13px;font-weight:700;opacity:.85}.stamp--press{animation:stamp-press .42s cubic-bezier(.2,1.3,.45,1) both}.stamp--sm{padding:6px 10px;border-width:2.5px}.stamp--sm .stamp__score{font-size:19px}.stamp--sm .stamp__pct{font-size:10.5px}@keyframes stamp-press{0%{transform:rotate(-6deg) scale(2.1);opacity:0}60%{transform:rotate(-6deg) scale(.92);opacity:1}to{transform:rotate(-6deg) scale(1);opacity:1}}.mascot{display:block;object-fit:contain}.bob{animation:bob 3.2s ease-in-out infinite}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.pulse{animation:pulse .9s ease-out}@keyframes pulse{0%{box-shadow:0 0 #2f8f5b59}to{box-shadow:0 0 0 14px #2f8f5b00}}.spinner{width:18px;height:18px;border-radius:50%;border:2.5px solid var(--line-strong);border-top-color:var(--goblin);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.wb{display:flex;flex-direction:column;gap:12px}.wb__rail{display:flex;align-items:center;gap:8px;flex-wrap:wrap;background:var(--surface);border:1.5px solid var(--line);border-radius:999px;padding:7px 12px;box-shadow:var(--shadow-sm)}.tool{border:1.5px solid var(--line-strong);background:var(--surface);border-radius:999px;padding:7px 14px;font-weight:600;font-size:14px;cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease}.tool:hover{border-color:var(--ink-soft)}.tool.is-active{background:var(--ink);color:#fff;border-color:var(--ink)}.wb__colors{display:flex;gap:7px;padding-left:4px}.swatch{width:26px;height:26px;border-radius:50%;border:2px solid var(--line-strong);cursor:pointer;padding:0;transition:transform .1s ease,box-shadow .12s ease}.swatch.is-active{box-shadow:0 0 0 3px var(--goblin-soft);border-color:var(--goblin);transform:scale(1.08)}.wb__surface{position:relative;width:100%;aspect-ratio:16 / 10;background:#fff;border:2px solid var(--line-strong);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.wb__canvas{display:block;width:100%;height:100%}.wb__overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#fbfaf6d6;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);padding:20px}.wb__actions{display:flex;align-items:center;gap:12px}.prompt-banner{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--surface);border:1.5px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.prompt-banner__idx{font-family:var(--font-mono);font-weight:700;color:var(--goblin-deep);flex:none}.prompt-banner__text{font-weight:600;font-size:17px}.result-panel{display:grid;justify-items:center;gap:14px;text-align:center;max-width:360px}.result-panel__feedback{color:var(--ink-soft);font-size:15px;line-height:1.5}.result-panel__meta{font-family:var(--font-mono);font-size:12px;color:var(--slate)}.landing{min-height:100%;display:flex;flex-direction:column}.landing__body{flex:1;display:grid;place-items:center;padding:24px}.hero{display:grid;justify-items:center;gap:16px;text-align:center;max-width:620px}.hero__title{font-size:clamp(52px,11vw,92px);letter-spacing:-.04em}.hero__title .dot{color:var(--goblin)}.hero__tag{font-size:clamp(16px,2.4vw,20px);color:var(--slate)}.hero__mascotline{display:inline-flex;align-items:center;gap:12px;font-family:var(--font-mono);font-size:14px;color:var(--ink-soft);margin-top:4px}.doors{display:grid;grid-template-columns:1fr 1fr;gap:16px;width:100%;max-width:560px;margin-top:14px}.door{display:grid;gap:4px;padding:26px 22px;border-radius:var(--radius-lg);border:1.5px solid var(--line-strong);background:var(--surface);text-decoration:none;color:var(--ink);text-align:left;transition:transform .1s ease,box-shadow .15s ease,border-color .15s ease;box-shadow:var(--shadow-sm)}.door:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--goblin)}.door__role{font-family:var(--font-display);font-weight:800;font-size:21px}.door__sub{color:var(--slate);font-size:14px}@media (max-width: 520px){.doors{grid-template-columns:1fr}}.page-head{display:grid;gap:6px;margin-bottom:22px}.page-head--join{margin-bottom:4px}.join-mascot{display:block;width:clamp(120px,40vw,200px);height:auto;margin:20px auto 0}.page-title{font-size:clamp(28px,5vw,40px)}.problem-row{display:flex;align-items:center;gap:10px}.problem-row__num{font-family:var(--font-mono);color:var(--slate);width:20px;text-align:right;flex:none}.problem-row .input{flex:1}.form-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.rubric-problem{border:1.5px solid var(--line);border-radius:var(--radius);padding:16px 18px;background:var(--surface);box-shadow:var(--shadow-sm)}.rubric-problem__head{display:flex;align-items:baseline;gap:8px;margin-bottom:6px}.rubric-problem__tag{font-family:var(--font-mono);font-size:12px;color:var(--goblin-deep);font-weight:700}.rubric-problem__prompt{font-weight:600}.criterion{display:flex;align-items:center;gap:10px;padding:9px 0;border-top:1px dashed var(--line)}.criterion:first-of-type{border-top:none}.criterion .input{flex:1}.criterion__pts{display:flex;align-items:center;gap:6px;color:var(--slate);font-size:13px}.dash-head{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:18px}.dash-title{font-size:clamp(24px,4vw,36px)}.metrics{display:flex;gap:22px}.metric{display:grid;gap:2px}.metric__n{font-family:var(--font-mono);font-size:22px;font-weight:700;line-height:1}.metric__l{font-size:11px;color:var(--slate);text-transform:uppercase;letter-spacing:.06em}.toolbar-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}.board-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(196px,1fr));gap:14px}.student-card{display:grid;gap:12px;padding:16px;min-height:132px;background:var(--surface);border:1.5px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.student-card__top{display:flex;align-items:center;justify-content:space-between;gap:8px}.student-card__name{font-weight:700;font-size:16px}.student-card__body{display:flex;align-items:center;justify-content:space-between;gap:8px}.student-card__meta{font-size:13px;color:var(--slate)}.progress-bar{height:6px;border-radius:999px;background:var(--surface-sunk);overflow:hidden}.progress-bar>span{display:block;height:100%;background:var(--goblin);border-radius:999px;transition:width .4s ease}.share{display:grid;justify-items:center;gap:16px;text-align:center;padding:40px 24px}.share__code{font-family:var(--font-mono);font-weight:700;font-size:clamp(38px,8vw,68px);letter-spacing:.16em;background:var(--ink);color:var(--board);padding:14px 28px;border-radius:var(--radius);box-shadow:var(--shadow)}.share__url{font-family:var(--font-mono);color:var(--slate)}.problem-list{display:flex;flex-direction:column;gap:10px}.problem-item{display:flex;align-items:center;gap:14px;padding:15px 18px;text-decoration:none;color:inherit;transition:transform .1s ease,box-shadow .15s ease,border-color .15s ease}.problem-item:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--line-strong)}.problem-item__idx{font-family:var(--font-mono);color:var(--slate);font-weight:700;flex:none}.problem-item__prompt{flex:1;font-weight:500}
