:root{--primary: #ff8c1a;--primary-hover: #ff7a00;--primary-soft: #fff4e6;--accent: #4c97ff;--accent-hover: #3b86ee;--bg: #f5f6fa;--bg-card: #ffffff;--border: #e6e8ef;--border-strong: #d6d9e3;--text: #1f2330;--text-soft: #6b7280;--text-mute: #9aa0ac;--success: #16a34a;--warning: #f59e0b;--danger: #ef4444;--info: #2563eb;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .04), 0 1px 3px rgba(15, 23, 42, .06);--shadow-md: 0 4px 12px rgba(15, 23, 42, .06), 0 2px 4px rgba(15, 23, 42, .04);--shadow-lg: 0 12px 32px rgba(15, 23, 42, .08);--radius: 12px;--radius-sm: 8px}*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,Noto Sans SC,sans-serif;background:radial-gradient(1200px 600px at -10% -20%,rgba(255,140,26,.08),transparent 60%),radial-gradient(900px 500px at 110% 0%,rgba(76,151,255,.08),transparent 60%),var(--bg);background-attachment:fixed;color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--accent);text-decoration:none;transition:color .15s ease}a:hover{color:var(--accent-hover);text-decoration:none}.nav{display:flex;align-items:center;gap:20px;padding:14px 28px;background:#ffffffd9;backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50}.nav .brand{display:inline-flex;align-items:center;gap:8px;font-weight:800;font-size:19px;letter-spacing:.2px;white-space:nowrap}.brand-emoji{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,#ff8c1a,#ff5c8a 60%,#b15bff);font-size:18px;box-shadow:0 4px 10px #ff7a0052;transition:transform .25s ease}.brand-link:hover .brand-emoji{transform:rotate(-8deg) scale(1.06)}.brand-cn{background:linear-gradient(135deg,#ff8c1a 10%,#ff5c8a 60%,#b15bff);-webkit-background-clip:text;background-clip:text;color:transparent;font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,sans-serif;font-weight:900;letter-spacing:1px}.brand-dot{color:var(--text-mute);font-weight:400;margin:0 -2px}.brand-en{font-family:SF Pro Display,Helvetica Neue,Segoe UI,system-ui,sans-serif;font-weight:800;font-size:17px;letter-spacing:2px;color:var(--text);display:inline-flex;align-items:center;gap:4px}.brand-oj{display:inline-block;margin-left:4px;padding:2px 7px 2px 8px;background:linear-gradient(135deg,var(--primary),var(--primary-hover));color:#fff;border-radius:6px;font-size:13px;letter-spacing:1.5px;box-shadow:0 2px 6px #ff7a0047;transform:translateY(-1px)}.nav .brand-link{display:inline-flex;transition:opacity .15s ease}.nav .brand-link:hover{opacity:.92;text-decoration:none}.nav>a{color:var(--text-soft);font-size:14px;font-weight:500;padding:6px 10px;border-radius:6px;transition:all .15s ease}.nav>a:hover{color:var(--primary);background:var(--primary-soft)}.nav .spacer{flex:1}.nav span{color:var(--text-soft);font-size:14px}.nav-links{display:flex;align-items:center;gap:4px;margin-left:18px;padding:4px;background:#f8fafdb3;border-radius:12px;border:1px solid var(--border)}.nav-link{position:relative;display:inline-flex;align-items:center;gap:6px;padding:7px 14px;font-size:14px;font-weight:500;color:var(--text-soft);border-radius:8px;transition:color .15s ease,background .15s ease,transform .12s ease}.nav-link:hover{color:var(--primary);background:var(--primary-soft);text-decoration:none}.nav-link.active{color:#fff;background:linear-gradient(135deg,var(--primary),var(--primary-hover));box-shadow:0 4px 10px #ff7a0047}.nav-link.active:hover{color:#fff}.nav-link .ni-icon{font-size:14px;display:inline-flex;align-items:center;transform:translateY(-.5px)}.user-chip{display:inline-flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;background:var(--bg-card);border:1px solid var(--border);border-radius:999px;font-size:13px;color:var(--text);box-shadow:var(--shadow-sm)}.user-avatar{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:linear-gradient(135deg,var(--primary),#ff5c8a);color:#fff;font-weight:700;font-size:13px;letter-spacing:0}.user-name{font-weight:500}.user-role{display:inline-block;padding:1px 7px;border-radius:999px;font-size:11px;letter-spacing:.4px;font-weight:600;text-transform:uppercase}.user-role.role-admin{background:linear-gradient(135deg,#b15bff,#4c97ff);color:#fff}.user-role.role-user{background:var(--primary-soft);color:var(--primary-hover)}@media (max-width: 760px){.nav{gap:10px;padding:12px 14px;flex-wrap:wrap}.nav-links{margin-left:0;order:10;flex-basis:100%}.nav-link{padding:6px 10px}.nav-link .ni-icon{display:none}}.container{max-width:1100px;margin:0 auto;padding:28px 24px 64px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:22px 24px;margin-bottom:18px;box-shadow:var(--shadow-sm);transition:box-shadow .2s ease,transform .2s ease}.card:hover{box-shadow:var(--shadow-md)}.card h2,.card h3{margin-top:0;letter-spacing:.2px}.card h2{font-size:22px}.card h3{font-size:16px;color:var(--text)}table{width:100%;border-collapse:separate;border-spacing:0;background:var(--bg-card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border)}th,td{padding:12px 16px;border-bottom:1px solid var(--border);text-align:left;font-size:14px}th{background:#fafbfd;font-weight:600;color:var(--text-soft);font-size:13px;text-transform:uppercase;letter-spacing:.4px}tr:last-child td{border-bottom:0}tbody tr{transition:background .15s ease}tbody tr:hover{background:#fafbfd}button,.btn{background:linear-gradient(180deg,var(--primary),var(--primary-hover));color:#fff;border:0;padding:8px 16px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:transform .08s ease,box-shadow .15s ease,opacity .15s ease,filter .15s ease;box-shadow:0 1px 2px #ff7a0040,0 2px 8px #ff8c1a2e;letter-spacing:.2px}button:hover:not(:disabled),.btn:hover{filter:brightness(1.04);box-shadow:0 2px 4px #ff7a004d,0 6px 14px #ff8c1a38}button:active:not(:disabled),.btn:active{transform:translateY(1px)}button:disabled{background:#d1d5db;box-shadow:none;cursor:not-allowed;opacity:.8}button.ghost,.btn.ghost{background:var(--bg-card);color:var(--primary);border:1px solid var(--primary);box-shadow:none}button.ghost:hover,.btn.ghost:hover{background:var(--primary-soft);filter:none;box-shadow:none}button.danger{background:linear-gradient(180deg,#f87171,var(--danger));box-shadow:0 1px 2px #ef444440,0 2px 8px #ef44442e}input,textarea,select{font-family:inherit;font-size:14px;padding:9px 12px;border:1px solid var(--border-strong);border-radius:8px;width:100%;background:#fff;color:var(--text);transition:border-color .15s ease,box-shadow .15s ease}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #ff8c1a2e}textarea{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;line-height:1.55}input[type=file]{padding:8px;background:#fafbfd;cursor:pointer}input[type=file]::file-selector-button{background:var(--primary-soft);color:var(--primary);border:0;padding:6px 12px;border-radius:6px;margin-right:12px;font-size:13px;cursor:pointer;font-weight:500}input[type=file]::file-selector-button:hover{background:bisque}label{display:block;margin:10px 0 6px;font-size:13px;color:var(--text-soft);font-weight:500}.status-AC,.status-WA,.status-TLE,.status-RE,.status-SE,.status-PENDING,.status-JUDGING{display:inline-flex;align-items:center;justify-content:center;min-width:44px;padding:3px 12px;border-radius:999px;font-size:12px;font-weight:600;letter-spacing:.4px;line-height:1.4;vertical-align:middle}.status-AC{color:var(--success);background:#dcfce7}.status-WA{color:var(--danger);background:#fee2e2}.status-TLE{color:#c2410c;background:#ffedd5}.status-RE,.status-SE{color:#be185d;background:#fce7f3}.status-PENDING,.status-JUDGING{color:var(--info);background:#dbeafe}.row{display:flex;gap:12px;align-items:center}.row>*{flex:1}.row.tight{gap:6px}pre{background:#f8fafc;padding:14px 16px;border-radius:8px;overflow:auto;font-size:13px;border:1px solid var(--border);line-height:1.5}code{background:#f1f5f9;padding:1px 6px;border-radius:4px;font-size:.92em;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.markdown-body{line-height:1.7;color:var(--text);font-size:15px}.markdown-body h1,.markdown-body h2,.markdown-body h3,.markdown-body h4,.markdown-body h5,.markdown-body h6{margin:1.2em 0 .6em;font-weight:700;line-height:1.3}.markdown-body h1{font-size:1.6em;border-bottom:1px solid var(--border);padding-bottom:.3em}.markdown-body h2{font-size:1.35em;border-bottom:1px solid var(--border);padding-bottom:.3em}.markdown-body h3{font-size:1.15em}.markdown-body h4{font-size:1em}.markdown-body p{margin:.8em 0}.markdown-body ul,.markdown-body ol{padding-left:1.6em;margin:.6em 0}.markdown-body li{margin:.25em 0}.markdown-body blockquote{border-left:4px solid var(--primary);background:var(--primary-soft);margin:.8em 0;padding:.6em 1em;color:#7c3a00;border-radius:0 6px 6px 0}.markdown-body blockquote p{margin:.3em 0}.markdown-body code{background:#f1f5f9;padding:1px 6px;border-radius:4px;font-size:.92em}.markdown-body pre{background:#0f172a;color:#e2e8f0;padding:14px 16px;border-radius:8px;overflow:auto;border:0}.markdown-body pre code{background:transparent;color:inherit;padding:0}.markdown-body table{margin:.8em 0;border-radius:6px}.markdown-body img{max-width:100%;height:auto;border-radius:6px;display:block;margin:8px 0}.markdown-body hr{border:0;border-top:1px solid var(--border);margin:1.5em 0}.markdown-body a{color:var(--accent)}.muted{color:var(--text-mute)}.meta{color:var(--text-soft);font-size:13px}::selection{background:var(--primary-soft);color:#7c3a00}.dropzone{border:2px dashed var(--border-strong);border-radius:12px;background:#fafbfd;padding:36px 20px;text-align:center;cursor:pointer;transition:border-color .15s ease,background .15s ease,transform .12s ease;-webkit-user-select:none;user-select:none}.dropzone:hover{border-color:var(--primary);background:var(--primary-soft)}.dropzone.over{border-color:var(--primary);background:var(--primary-soft);transform:scale(1.01)}.dropzone.busy{cursor:wait;border-color:var(--accent);background:#eff6ff}.dz-icon{display:inline-flex;align-items:center;justify-content:center;min-width:54px;min-height:30px;padding:6px 10px;border-radius:999px;background:#ff8c1a1f;color:var(--primary-hover);font-size:13px;font-weight:900;line-height:1;margin-bottom:10px}.dz-title{font-size:15px;font-weight:600;color:var(--text)}.dz-sub{font-size:13px;color:var(--text-soft);margin-top:4px}.desc-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:4px 0 6px}textarea.desc-drag{outline:2px dashed var(--brand, #ff8a3c);outline-offset:-4px;background:#ff8a3c0f}.editor-frame{margin-top:16px;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:#2c2c2c;box-shadow:var(--shadow-md);animation:editorSlide .3s ease}.card:has(.editor-frame){max-width:none;width:calc(100vw - 48px);margin-left:calc(-50vw + 50% + 24px);margin-right:calc(-50vw + 50% + 24px)}@media (max-width: 1200px){.card:has(.editor-frame){width:auto;margin-left:0;margin-right:0}}@keyframes editorSlide{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.editor-frame iframe{display:block;width:100%;height:820px;border:0;background:#fff}.editor-tip{padding:10px 14px;background:var(--primary-soft);color:#7c3a00;font-size:13px;border-top:1px solid #ffe1bd}.tc-form{display:flex;flex-direction:column;gap:14px}.tc-section{padding:14px;background:#fafbfd;border:1px solid var(--border);border-radius:10px}.tc-section-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px}.tc-tag{display:inline-block;padding:2px 9px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.4px}.tc-tag.in{background:#dbeafe;color:#1d4ed8}.tc-tag.out{background:#dcfce7;color:#15803d}.tc-help{color:var(--text-mute);font-size:12px}.tc-add{margin-left:auto;padding:4px 12px;font-size:12px}.tc-empty{color:var(--text-mute);font-size:13px;margin:0;padding:6px 0 2px}.tc-row{display:grid;grid-template-columns:1fr auto 1fr auto;gap:8px;align-items:center;margin-bottom:8px}.tc-row.tc-row-textarea{align-items:start}.tc-row.tc-row-textarea textarea{min-height:50px;resize:vertical;font-family:inherit}.tc-row.tc-row-range{grid-template-columns:1.4fr auto 1fr auto 1fr auto auto}.tc-row select{padding:7px 10px;font-size:13px}.tc-sprite-card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin-bottom:10px}.tc-sprite-card:last-child{margin-bottom:0}.tc-attr-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px 18px;margin-top:10px}.tc-attr{display:grid;grid-template-columns:80px 1fr auto 1fr 1fr;gap:6px;align-items:center}.tc-attr-name{font-size:12px;color:var(--text-soft);font-weight:500}.tc-attr-or{font-size:11px;color:var(--text-mute);text-align:center}.tc-attr input,.tc-attr select{padding:5px 8px;font-size:12px}@media (max-width: 760px){.tc-attr-grid{grid-template-columns:1fr}}.tc-pen-card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:10px}.tc-pen-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.tc-pen-label{min-width:130px;font-size:13px;color:var(--text-soft);font-weight:500}.tc-pen-row select{width:auto;min-width:110px}.tc-pen-row input[type=text],.tc-pen-row input:not([type]){width:auto;flex:1;min-width:100px;max-width:200px}.tc-pen-row-list{align-items:flex-start}.tc-pen-list{flex:1;min-width:0}.tc-row:last-child{margin-bottom:0}.tc-row input{padding:7px 10px;font-size:13px}.tc-eq{font-size:13px;color:var(--text-soft);font-weight:500;padding:0 4px;white-space:nowrap}.tc-idx{font-size:12px;color:var(--text-soft);background:#fff;border:1px solid var(--border);padding:6px 10px;border-radius:6px;white-space:nowrap}.tc-del{padding:4px 10px;font-size:13px;font-weight:700;line-height:1;border-radius:6px;box-shadow:none}@media (max-width: 640px){.tc-row{grid-template-columns:1fr}.tc-eq{padding:0;text-align:left}}.scratch-home{display:flex;flex-direction:column;gap:18px}.scratch-hero{display:grid;grid-template-columns:minmax(0,.95fr) minmax(380px,1.05fr);gap:28px;align-items:stretch;min-height:430px;padding:32px;border:1px solid #ffe1bd;border-radius:20px;background:linear-gradient(90deg,rgba(255,140,26,.08) 1px,transparent 1px),linear-gradient(0deg,rgba(255,140,26,.08) 1px,transparent 1px),linear-gradient(135deg,#fffdf9,#fff4e6 45%,#eef6ff);background-size:34px 34px,34px 34px,auto;box-shadow:0 22px 55px #ff7a0021;overflow:hidden}.scratch-hero-copy{display:flex;flex-direction:column;justify-content:center;min-width:0}.scratch-kicker,.scratch-panel-head span,.flow-label{color:var(--primary-hover);font-size:12px;font-weight:900;letter-spacing:1.8px;text-transform:uppercase}.scratch-hero h1{max-width:620px;margin:14px 0;font-size:44px;line-height:1.1;letter-spacing:0;color:#18141f}.scratch-hero p{max-width:560px;margin:0;color:#5f6574;font-size:16px;line-height:1.8}.scratch-hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:24px}.scratch-primary-action,.scratch-secondary-action{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:10px 18px;border-radius:10px;font-weight:800;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease,background .15s ease}.scratch-primary-action{color:#fff;background:linear-gradient(135deg,#ff8c1a,#ff5c8a);box-shadow:0 12px 24px #ff5c8a38}.scratch-primary-action:hover{color:#fff;text-decoration:none;transform:translateY(-1px);box-shadow:0 16px 30px #ff5c8a47}.scratch-secondary-action{color:#2b2f3a;background:#ffffffb3;border:1px solid #f2d8bd}.scratch-secondary-action:hover{color:var(--primary-hover);text-decoration:none;border-color:#ffc489;background:#fff}.scratch-stat-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:28px;max-width:520px}.scratch-stat-row div{padding:14px;background:#ffffffbd;border:1px solid rgba(255,196,137,.65);border-radius:12px}.scratch-stat-row strong{display:block;color:#18141f;font-size:24px;line-height:1}.scratch-stat-row span{display:block;margin-top:5px;color:var(--text-soft);font-size:12px;font-weight:700}.scratch-workspace{align-self:center;min-width:0;border:1px solid rgba(34,41,58,.14);border-radius:18px;background:#fff;box-shadow:0 24px 50px #1f233024;overflow:hidden}.workspace-toolbar{display:flex;align-items:center;gap:7px;padding:12px 14px;background:#202331;color:#c9cedb;font-size:12px;font-weight:700}.workspace-dot{width:10px;height:10px;border-radius:50%}.dot-red{background:#ff5c8a}.dot-yellow{background:#ffcf5a}.dot-green{background:#5ee08f}.workspace-title{margin-left:8px}.workspace-body{display:grid;grid-template-columns:.9fr 1.1fr;min-height:310px;background:#f5f6fa}.block-lane{display:flex;flex-direction:column;gap:9px;padding:22px 18px;border-right:1px solid var(--border)}.scratch-block{position:relative;max-width:220px;min-height:35px;padding:9px 13px 9px 16px;border-radius:8px;color:#fff;font-size:13px;font-weight:800;box-shadow:inset 0 -2px #00000029,0 8px 16px #0f172a1a}.scratch-block:after{content:"";position:absolute;left:24px;bottom:-5px;width:34px;height:9px;border-radius:0 0 7px 7px;background:inherit}.block-event{background:#ffbf00;color:#2b2f3a}.block-motion{background:#4c97ff;margin-left:22px}.block-control{background:#ffab19;color:#2b2f3a;margin-left:12px}.block-looks{background:#96f;margin-left:34px}.stage-card{position:relative;margin:18px;border:1px solid #d8e7ff;border-radius:14px;background:linear-gradient(180deg,#edf7ff,#fff 70%);overflow:hidden}.stage-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(76,151,255,.12) 1px,transparent 1px),linear-gradient(90deg,rgba(76,151,255,.12) 1px,transparent 1px);background-size:28px 28px}.stage-cat{position:absolute;left:34px;bottom:42px;width:86px;height:76px;border-radius:42% 42% 48% 48%;background:#ff8c1a;border:4px solid #2f2a22;color:#2f2a22;font-size:20px;font-weight:900;transform:rotate(-5deg);box-shadow:0 12px 22px #ff8c1a3d}.cat-ear{position:absolute;top:-21px;width:28px;height:28px;background:#ff8c1a;border:4px solid #2f2a22;transform:rotate(45deg)}.cat-ear.left{left:8px}.cat-ear.right{right:8px}.cat-face{position:absolute;left:0;right:0;top:23px;text-align:center}.stage-bubble{position:absolute;left:126px;bottom:126px;padding:8px 14px;border-radius:16px 16px 16px 4px;background:#fff;border:2px solid #2f2a22;font-weight:900}.stage-score{position:absolute;right:16px;top:16px;display:flex;flex-direction:column;align-items:flex-end;padding:10px 12px;border-radius:12px;background:#ffffffdb;border:1px solid #dbe7f4}.stage-score b{font-size:24px;color:var(--success);line-height:1}.stage-score span{color:var(--text-soft);font-size:11px;font-weight:800;text-transform:uppercase}.scratch-command-grid{display:grid;grid-template-columns:1.15fr 1fr 1fr;gap:14px}.scratch-command{display:flex;align-items:center;gap:14px;min-height:96px;padding:18px;border:1px solid var(--border);border-radius:14px;background:#fff;color:var(--text);box-shadow:var(--shadow-sm);transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.scratch-command:hover{color:var(--text);text-decoration:none;transform:translateY(-2px);border-color:#ffc489;box-shadow:var(--shadow-md)}.scratch-command.start{background:linear-gradient(135deg,#202331,#34384b);color:#fff;border-color:#202331}.scratch-command b,.scratch-command em{display:block;font-style:normal}.scratch-command b{font-size:16px;margin-bottom:4px}.scratch-command em{color:var(--text-soft);font-size:13px;line-height:1.4}.scratch-command.start em{color:#ffffffb8}.command-icon{width:44px;height:44px;border-radius:12px;flex:0 0 auto;background:var(--primary-soft);position:relative}.icon-blocks:before,.icon-blocks:after,.icon-book:before,.icon-timer:before{content:"";position:absolute}.icon-blocks:before{left:10px;top:11px;width:24px;height:10px;border-radius:4px;background:#ff8c1a;box-shadow:0 13px #4c97ff}.icon-book:before{left:11px;top:9px;width:22px;height:27px;border-radius:4px 8px 8px 4px;background:#ff5c8a;box-shadow:inset 5px 0 #ffffff59}.icon-timer:before{left:11px;top:12px;width:22px;height:22px;border:4px solid #4c97ff;border-radius:50%}.scratch-home-grid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(330px,.65fr);gap:16px}.scratch-side-stack{display:flex;flex-direction:column;gap:16px}.scratch-panel{background:#fff;border:1px solid var(--border);border-radius:14px;padding:18px;box-shadow:var(--shadow-sm)}.scratch-panel-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:14px}.scratch-panel-head h2{margin:4px 0 0;font-size:22px}.scratch-panel-head.compact h2{font-size:18px}.scratch-panel-head a{color:var(--text-soft);font-size:13px;font-weight:800}.scratch-problem-list,.scratch-task-list{display:flex;flex-direction:column;gap:8px}.scratch-problem-item,.scratch-task-item{display:grid;align-items:center;gap:12px;padding:12px;border:1px solid #eef0f5;border-radius:10px;color:var(--text);transition:background .15s ease,border-color .15s ease,transform .15s ease}.scratch-problem-item{grid-template-columns:64px minmax(0,1fr) 80px}.scratch-problem-item:hover,.scratch-task-item:hover{color:var(--text);text-decoration:none;background:#fff9f2;border-color:#ffc489;transform:translate(2px)}.problem-id{color:var(--primary-hover);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-weight:900}.problem-title,.task-title{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:700}.problem-limit,.task-state{color:var(--text-mute);font-size:12px;text-align:right}.scratch-task-item{grid-template-columns:46px minmax(0,1fr);row-gap:4px}.task-type{grid-row:span 2;align-self:center;padding:5px 8px;border-radius:8px;background:var(--primary-soft);color:var(--primary-hover);font-size:12px;font-weight:900;text-align:center}.task-state{text-align:left}.scratch-rank-list{list-style:none;padding:0;margin:0}.scratch-rank-list li{display:grid;grid-template-columns:28px minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px 0;border-top:1px solid var(--border)}.scratch-rank-list li:first-child{border-top:0}.rank-pos{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border-radius:9px;background:#eef0f5;color:var(--text-soft);font-size:12px;font-weight:900}.pos-1{background:#ffcf5a;color:#5d3900}.pos-2{background:#dce2ed;color:#4b5563}.pos-3{background:#f0b38a;color:#6f3312}.scratch-rank-list b{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scratch-rank-list em{color:var(--success);font-size:12px;font-style:normal;font-weight:900}.scratch-empty{margin:0;color:var(--text-soft);font-size:14px}.scratch-flow{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:20px 22px;border:1px solid #d8e7ff;border-radius:14px;background:linear-gradient(135deg,#f4f9ff,#fff)}.scratch-flow h2{margin:4px 0 0;font-size:20px}.flow-steps{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.flow-steps span{padding:8px 12px;border-radius:10px;background:#fff;border:1px solid var(--border);color:var(--text);font-size:13px;font-weight:800}.flow-steps i{width:24px;height:2px;background:#bcd6ff}@media (max-width: 980px){.scratch-hero,.scratch-home-grid{grid-template-columns:1fr}.scratch-workspace{width:100%}.scratch-command-grid{grid-template-columns:1fr}}@media (max-width: 680px){.scratch-hero{padding:22px}.scratch-hero h1{font-size:32px}.scratch-stat-row,.workspace-body{grid-template-columns:1fr}.block-lane{border-right:0;border-bottom:1px solid var(--border)}.stage-card{min-height:210px}.scratch-problem-item{grid-template-columns:52px minmax(0,1fr)}.problem-limit{grid-column:2;text-align:left}.scratch-flow{align-items:flex-start;flex-direction:column}}.container>*{animation:fadeIn .25s ease both}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.assign-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.assign-card{display:block;background:#fff;border:1px solid var(--border);border-radius:12px;padding:16px;text-decoration:none;color:inherit;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.assign-card:hover{transform:translateY(-2px);box-shadow:0 6px 18px #0000000f;border-color:var(--border-strong)}.assign-card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.assign-card-title{margin:0 0 8px;font-size:16px}.assign-card-meta{font-size:12px;color:var(--muted, #777);line-height:1.7}.assign-card-foot{margin-top:8px;font-size:12px;color:var(--muted, #777);border-top:1px dashed var(--border);padding-top:6px}.tag{display:inline-block;font-size:11px;padding:2px 8px;border-radius:999px;background:#eef;color:#335}.tag.active{background:#e8f7ec;color:#2a7a3a}.tag.pending{background:#fff4dc;color:#946100}.tag.ended{background:#f0f0f0;color:#888}.assign-prob-count{font-size:12px;color:var(--muted, #777)}.assign-banner{margin:8px 0 12px;padding:10px 14px;border-radius:10px;background:#fff4dc;color:#946100;font-size:14px}.assign-banner.running{background:#e8f7ec;color:#2a7a3a}.assign-banner.ended{background:#f0f0f0;color:#888}.assign-banner b{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.assignment-banner{background:linear-gradient(90deg,#fff4dc,#fff)}.check-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:6px 12px;max-height:320px;overflow:auto;padding:8px;border:1px solid var(--border);border-radius:8px;background:#fafbfd}.check-item{display:flex;align-items:center;gap:8px;font-size:13px;padding:4px 6px;border-radius:6px}.check-item:hover{background:#eef3fb}.check-item input{width:auto}.picked-list{border:1px solid var(--border);border-radius:8px;padding:8px;background:#fffaf2;margin-bottom:8px}.picked-item{display:flex;align-items:center;gap:8px;padding:4px 6px;border-bottom:1px dashed var(--border);font-size:13px}.picked-item:last-child{border-bottom:0}.picked-idx{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--primary-soft, #ffe5d0);border-radius:50%;font-size:12px;font-weight:600}.picked-title{flex:1}.participant-chips{display:flex;flex-wrap:wrap;gap:6px}.chip{display:inline-block;padding:3px 10px;background:var(--primary-soft, #ffe5d0);border-radius:999px;font-size:12px}html,body{min-height:100%;height:auto}#root{min-height:100vh}body{background:linear-gradient(90deg,rgba(255,140,26,.052) 1px,transparent 1px),linear-gradient(0deg,rgba(76,151,255,.052) 1px,transparent 1px),linear-gradient(180deg,#fffdf8,#f7f9fd 52%,#f4f8fb);background-size:42px 42px,42px 42px,auto}.nav{background:#ffffffeb;box-shadow:0 8px 24px #0f172a0e}.nav-links{background:#faf8f5e6;box-shadow:inset 0 1px #fffc}.card,table,.assign-card,.editor-panel,.panel{box-shadow:0 8px 24px #0f172a0e}.card,.assign-card{transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}.card:hover,.assign-card:hover{border-color:#ff8c1a4d;box-shadow:0 14px 34px #0f172a14}button,.btn{box-shadow:0 8px 18px #ff8c1a29}button.ghost,.btn.ghost{background:#ffffffc7;box-shadow:none}input,select,textarea{background:#fffffff0;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}th{background:#fbf7f1}tr:hover td,.problem-row:hover{background:#fff8ee}.container:has(.scratch-home){max-width:1240px;padding-top:22px}.scratch-home{gap:20px}.scratch-hero{position:relative;border-color:#ff8c1a3d;border-radius:22px;background:linear-gradient(135deg,#ffffffe6,#fff6eadb 48%,#eef6ffe6),repeating-linear-gradient(90deg,rgba(255,140,26,.08) 0 1px,transparent 1px 26px);box-shadow:0 30px 70px #7e410c1f}.scratch-hero:before{content:"";position:absolute;left:-36px;right:-36px;top:54%;height:74px;background:linear-gradient(90deg,#ff8c1a2e,#4c97ff29,#ff5c8a24);transform:rotate(-3deg)}.scratch-hero>*{position:relative;z-index:1}.scratch-kicker,.scratch-panel-head span,.flow-label{text-transform:none;letter-spacing:.08em}.scratch-hero h1{max-width:690px;color:#211827}.scratch-hero p{color:#566070}.scratch-stat-row div{border-color:#ff8c1a38;box-shadow:inset 0 1px #fffc}.scratch-workspace{transform:rotate(-1.3deg);box-shadow:0 30px 64px #1f233029}.scratch-workspace:hover{transform:rotate(0) translateY(-2px)}.scratch-panel,.scratch-command,.scratch-flow{border-radius:16px}.scratch-command.start{background:linear-gradient(135deg,rgba(255,140,26,.18),transparent 38%),linear-gradient(135deg,#202331,#353a50)}.scratch-panel{box-shadow:0 12px 30px #1f233012}.scratch-problem-item,.scratch-task-item{background:#ffffffdb;box-shadow:inset 0 1px #ffffffb8}.scratch-rank-list li{border-top-style:dashed}.scratch-flow{background:linear-gradient(135deg,#ffffffeb,#f4f9ffe6),repeating-linear-gradient(90deg,rgba(76,151,255,.08) 0 1px,transparent 1px 30px)}@media (max-width: 680px){.container:has(.scratch-home){padding-top:16px}.scratch-workspace{transform:none}}html{scroll-padding-top:76px}body{overflow-x:hidden}a,button,.btn,.nav-link,.scratch-command,.scratch-problem-item,.scratch-task-item{touch-action:manipulation}a:focus-visible,button:focus-visible,.btn:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,.nav-link:focus-visible{outline:3px solid rgba(255,140,26,.34);outline-offset:3px}.nav-link,button,.btn{min-height:40px}.brand-emoji,.ni-icon{position:relative;flex:0 0 auto;color:currentColor}.brand-emoji:before,.brand-emoji:after,.ni-icon:before,.ni-icon:after{content:"";position:absolute}.brand-emoji{overflow:hidden}.brand-scratch:before{left:7px;top:9px;width:18px;height:15px;border-radius:45% 45% 50% 50%;background:#fff}.brand-scratch:after{left:8px;top:5px;width:7px;height:7px;background:#fff;box-shadow:9px 0 #fff;transform:rotate(45deg)}.ni-icon{width:15px;height:15px;font-size:0}.ni-home:before{left:2px;top:6px;width:11px;height:8px;border:2px solid currentColor;border-top:0;border-radius:2px}.ni-home:after{left:2px;top:1px;width:10px;height:10px;border-left:2px solid currentColor;border-top:2px solid currentColor;transform:rotate(45deg)}.ni-problems:before,.ni-homework:before,.ni-exam:before{left:3px;top:1px;width:9px;height:13px;border:2px solid currentColor;border-radius:2px}.ni-problems:after,.ni-homework:after{left:6px;top:5px;width:6px;height:2px;background:currentColor;box-shadow:0 4px currentColor}.ni-exam:after{left:6px;top:4px;width:6px;height:7px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(36deg)}.ni-submit:before{left:2px;top:8px;width:11px;height:5px;border:2px solid currentColor;border-top:0;border-radius:0 0 3px 3px}.ni-submit:after{left:5px;top:1px;width:6px;height:8px;border-left:2px solid currentColor;border-top:2px solid currentColor;transform:rotate(45deg)}.ni-ranking:before{left:3px;top:2px;width:9px;height:7px;border:2px solid currentColor;border-radius:2px 2px 6px 6px}.ni-ranking:after{left:6px;top:10px;width:4px;height:4px;background:currentColor;box-shadow:-3px 4px 0 1px currentColor}.ni-users:before{left:1px;top:3px;width:6px;height:6px;border:2px solid currentColor;border-radius:50%;box-shadow:7px 0 0 -1px currentColor}.ni-users:after{left:0;top:10px;width:15px;height:5px;border:2px solid currentColor;border-radius:999px 999px 2px 2px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}
