@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;450;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap";@layer components;@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-font-weight:initial;--tw-outline-style:solid;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-red-500:oklch(63.7% .237 25.331);--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--font-weight-medium:500;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{.collapse{visibility:collapse}.block{display:block}.hidden{display:none}.inline-flex{display:inline-flex}.size-6{width:calc(var(--spacing) * 6);height:calc(var(--spacing) * 6)}.size-7{width:calc(var(--spacing) * 7);height:calc(var(--spacing) * 7)}.size-8{width:calc(var(--spacing) * 8);height:calc(var(--spacing) * 8)}.size-9{width:calc(var(--spacing) * 9);height:calc(var(--spacing) * 9)}.h-6{height:calc(var(--spacing) * 6)}.h-7{height:calc(var(--spacing) * 7)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.shrink-0{flex-shrink:0}.grow{flex-grow:1}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.items-center{align-items:center}.justify-center{justify-content:center}.gap-1{gap:var(--spacing)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.rounded-\[min\(var\(--radius-md\)\,10px\)\]{border-radius:min(var(--radius-md), 10px)}.rounded-\[min\(var\(--radius-md\)\,12px\)\]{border-radius:min(var(--radius-md), 12px)}.rounded-lg{border-radius:var(--radius-lg)}.border{border-style:var(--tw-border-style);border-width:1px}.border-transparent{border-color:#0000}.bg-clip-padding{background-clip:padding-box}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[0\.8rem\]{font-size:.8rem}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.whitespace-nowrap{white-space:nowrap}.text-red-500{color:var(--color-red-500)}.underline-offset-4{text-underline-offset:4px}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}@media (hover:hover){.hover\:underline:hover{text-decoration-line:underline}}.focus-visible\:ring-3:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.active\:not-aria-\[haspopup\]\:translate-y-px:active:not([aria-haspopup]){--tw-translate-y:1px;translate:var(--tw-translate-x) var(--tw-translate-y)}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:opacity-50:disabled{opacity:.5}:where([data-slot=button-group]) .in-data-\[slot\=button-group\]\:rounded-lg{border-radius:var(--radius-lg)}.has-data-\[icon\=inline-end\]\:pr-1\.5:has([data-icon=inline-end]){padding-right:calc(var(--spacing) * 1.5)}.has-data-\[icon\=inline-end\]\:pr-2:has([data-icon=inline-end]){padding-right:calc(var(--spacing) * 2)}.has-data-\[icon\=inline-start\]\:pl-1\.5:has([data-icon=inline-start]){padding-left:calc(var(--spacing) * 1.5)}.has-data-\[icon\=inline-start\]\:pl-2:has([data-icon=inline-start]){padding-left:calc(var(--spacing) * 2)}.aria-invalid\:ring-3[aria-invalid=true]{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-3 svg:not([class*=size-]){width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-3\.5 svg:not([class*=size-]){width:calc(var(--spacing) * 3.5);height:calc(var(--spacing) * 3.5)}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-4 svg:not([class*=size-]){width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}}:root{--font-sans:"Noto Serif SC", "Songti SC", "SimSun", serif;--font-mono:"JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--radius-sm:7px;--radius:11px;--radius-lg:16px;--shadow-sm:0 1px 2px #0f12190f;--shadow:0 6px 24px -10px #0f12192e;--shadow-lg:0 24px 60px -18px #0f121952}[data-theme=light]{--bg:#f0f0f0;--bg-grad:none;--surface:#f8f8f7;--surface-2:#f0f0f0;--surface-3:#e9e9e9;--border:#e3e3e3;--border-strong:#d4d4d4;--text:#1a1a1a;--text-muted:#6b6b6b;--text-faint:#9a9a9a;--accent:#1a1a1a;--accent-hover:#333;--accent-contrast:#f8f8f7;--accent-soft:#0000000f;--success:#2f7d4f;--success-soft:#2f7d4f1f;--danger:#b3403f;--danger-soft:#b3403f1a;--warning:#9a7320;--warning-soft:#9a73201f;--code-bg:#f0f0f0;--code-border:#e3e3e3;--scrollbar:#cdcdcd;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}[data-theme=dark]{--bg:#1a1a1a;--bg-grad:none;--surface:#1f1f1f;--surface-2:#282828;--surface-3:#333;--border:#303030;--border-strong:#3d3d3d;--text:#ededed;--text-muted:#9a9a9a;--text-faint:#6a6a6a;--accent:#ededed;--accent-hover:#fff;--accent-contrast:#1a1a1a;--accent-soft:#ffffff14;--success:#5bbd85;--success-soft:#5bbd8529;--danger:#e07a78;--danger-soft:#e07a7824;--warning:#cba960;--warning-soft:#cba96029;--code-bg:#1a1a1a;--code-border:#303030;--scrollbar:#3d3d3d;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}*{box-sizing:border-box;border-color:var(--border)}html,body,#root{height:100%;margin:0}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;overflow:hidden}#root{background:var(--bg-grad), var(--bg)}::selection{background:var(--accent-soft)}*{scrollbar-width:thin;scrollbar-color:var(--scrollbar) transparent}::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-thumb{background:var(--scrollbar);background-clip:padding-box;border:2px solid #0000;border-radius:8px}::-webkit-scrollbar-thumb:hover{background:var(--text-faint);background-clip:padding-box}::-webkit-scrollbar-track{background:0 0}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}.md{color:var(--text);word-break:break-word;font-size:14px;line-height:1.65}.md>:first-child{margin-top:0}.md>:last-child{margin-bottom:0}.md h1{letter-spacing:-.01em;margin:.6em 0 .5em;font-size:1.4em;font-weight:700}.md h2{margin:1em 0 .45em;font-size:1.2em;font-weight:650}.md h3{margin:.9em 0 .4em;font-size:1.05em;font-weight:600}.md p{margin:.55em 0}.md ul,.md ol{margin:.5em 0;padding-left:1.4em}.md li{margin:.25em 0}.md strong{color:var(--text);font-weight:650}.md a{color:var(--accent);text-decoration:none}.md a:hover{text-decoration:underline}.md blockquote{border-left:3px solid var(--accent);background:var(--accent-soft);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--text-muted);margin:.7em 0;padding:.3em .9em}.md code{font-family:var(--font-mono);background:var(--surface-3);border-radius:5px;padding:.12em .4em;font-size:.88em}.md pre{background:var(--code-bg);border:1px solid var(--code-border);border-radius:var(--radius);margin:.7em 0;padding:.9em 1em;overflow-x:auto}.md pre code{background:0 0;padding:0;font-size:.85em;line-height:1.55}.md table{border-collapse:collapse;width:100%;margin:.7em 0;font-size:.92em}.md th,.md td{border:1px solid var(--border);text-align:left;padding:.4em .65em}.md th{background:var(--surface-2);font-weight:600}.md hr{border:none;border-top:1px solid var(--border);margin:1em 0}.md .katex{font-size:1.04em}.md .katex-display{margin:.7em 0;padding:.2em 0;overflow:auto hidden}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes circle-keys{0%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}to{opacity:1;transform:scale(1)}}@keyframes dot-keys{0%{transform:translate(-50%,-50%)scale(1)}50%{transform:translate(-50%,-50%)scale(0)}to{transform:translate(-50%,-50%)scale(1)}}@keyframes outline-keys-accent{0%{outline:solid 8px var(--accent,#4f8ef7);outline-offset:0;opacity:1;transform:translate(-50%,-50%)scale(0)}to{outline-offset:10px;opacity:0;outline:0 solid #0000;transform:translate(-50%,-50%)scale(1)}}@keyframes outline-keys-warning{0%{outline:solid 8px var(--warning,#f59e0b);outline-offset:0;opacity:1;transform:translate(-50%,-50%)scale(0)}to{outline-offset:10px;opacity:0;outline:0 solid #0000;transform:translate(-50%,-50%)scale(1)}}@keyframes outline-keys-success{0%{outline:solid 8px var(--success,#22c55e);outline-offset:0;opacity:1;transform:translate(-50%,-50%)scale(0)}to{outline-offset:10px;opacity:0;outline:0 solid #0000;transform:translate(-50%,-50%)scale(1)}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{opacity:0;transform:translateY(12px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}.app{width:100vw;height:100vh;display:flex;overflow:hidden}.btn{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:var(--radius-sm);white-space:nowrap;justify-content:center;align-items:center;gap:7px;height:34px;padding:0 13px;font-size:13px;font-weight:550;transition:background .15s,border-color .15s,color .15s,transform 80ms,opacity .15s;display:inline-flex}.btn:hover{background:var(--surface-2);border-color:var(--border-strong)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn.primary{background:var(--accent);border-color:var(--accent);color:var(--accent-contrast)}.btn.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn.danger{color:var(--danger)}.btn.danger:hover{background:var(--danger-soft);border-color:var(--danger)}.btn.ghost{background:0 0;border-color:#0000}.btn.ghost:hover{background:var(--surface-2)}.btn.subtle{background:var(--surface-2);border-color:#0000}.btn.subtle:hover{background:var(--surface-3);border-color:#0000}.btn.success{color:#fff;background:#16a34a;border-color:#16a34a}.btn.success:hover{background:#15803d;border-color:#15803d}.btn.sm{gap:5px;height:29px;padding:0 10px;font-size:12px}.btn.block{width:100%}.icon-btn{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-muted);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.icon-btn:hover{background:var(--surface-2);color:var(--text)}.line-num-toggle{width:24px;height:24px;color:var(--text-faint);border-radius:5px}.line-num-toggle.active{color:var(--text-muted)}.icon-btn:disabled{opacity:.45;cursor:not-allowed}.field{border:1px solid var(--border);background:var(--surface);width:100%;height:38px;color:var(--text);border-radius:var(--radius-sm);outline:none;padding:0 12px;font-size:13px;transition:border-color .15s,box-shadow .15s}.field:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}textarea.field{resize:vertical;height:auto;padding:9px 12px;line-height:1.5}.field-label{color:var(--text-muted);margin-bottom:6px;font-size:12px;font-weight:550;display:block}.badge{border:1px solid var(--border);color:var(--text-muted);background:var(--surface-2);border-radius:999px;align-items:center;gap:5px;padding:2px 9px;font-size:11.5px;font-weight:550;display:inline-flex}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:268px;height:100%;display:flex}.sidebar-head{border-bottom:1px solid var(--border);padding:16px 16px 14px}.brand{align-items:center;gap:11px;display:flex}.brand-logo{background:var(--accent);width:38px;height:38px;color:var(--accent-contrast);box-shadow:var(--shadow-sm);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.brand-title{letter-spacing:-.01em;font-size:14px;font-weight:680;line-height:1.15}.brand-stacked{flex-direction:column;align-items:flex-start;gap:6px}.brand-icon{width:40px;height:40px;box-shadow:var(--shadow-sm);background:#1e54a4;border-radius:25px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.brand-icon-img{object-fit:contain;filter:brightness(0)invert();width:28px;height:28px}.brand-text{flex-direction:column;gap:2px;display:flex}.brand-sub{color:var(--text-faint);letter-spacing:.01em;font-size:11px}.sidebar-actions{padding:12px}.sidebar-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint);padding:4px 16px 8px;font-size:11px;font-weight:600}.problem-list{flex-direction:column;flex:1;gap:3px;padding:0 8px 12px;display:flex;overflow-y:auto}.problem-item{border-radius:var(--radius-sm);cursor:pointer;border:1px solid #0000;align-items:center;gap:10px;padding:9px 10px;transition:background .13s,border-color .13s;display:flex;position:relative}.problem-item:hover{background:var(--surface-2)}.problem-item.active{background:var(--accent-soft)}.problem-item.active .problem-name{color:var(--accent);font-weight:600}.problem-icon{color:var(--text-faint);flex-shrink:0}.problem-item.active .problem-icon{color:var(--accent)}.problem-name{white-space:nowrap;text-overflow:ellipsis;color:var(--text);flex:1;font-size:13px;font-weight:500;overflow:hidden}.problem-ops{opacity:0;gap:1px;transition:opacity .13s;display:flex}.problem-item:hover .problem-ops{opacity:1}.op-btn{width:24px;height:24px;color:var(--text-faint);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;display:inline-flex}.op-btn:hover{background:var(--surface-3);color:var(--text)}.op-btn.del:hover{color:var(--danger)}.rename-input{border:1px solid var(--accent);background:var(--surface);color:var(--text);border-radius:6px;outline:none;flex:1;padding:3px 7px;font-size:13px}.sidebar-empty{text-align:center;color:var(--text-faint);padding:30px 18px;font-size:12.5px;line-height:1.6}.main{flex-direction:column;flex:1;min-width:0;height:100%;display:flex}.topbar{border-bottom:1px solid var(--border);background:color-mix(in srgb, var(--surface) 75%, transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-shrink:0;justify-content:space-between;align-items:center;gap:14px;height:56px;padding:0 18px;display:flex}.topbar-title{letter-spacing:-.01em;white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:640;overflow:hidden}.topbar-left{align-items:center;gap:12px;min-width:0;display:flex}.topbar-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.py-status{border:1px solid var(--border);background:var(--surface-2);color:var(--text-muted);border-radius:999px;align-items:center;gap:7px;padding:5px 11px;font-size:12px;font-weight:550;display:inline-flex}.py-status .circle{--dot-color:var(--text-faint);--animation:2s ease-in-out infinite;border:solid 2px var(--dot-color);width:14px;height:14px;animation:circle-keys var(--animation);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.py-status .circle .dot{background:var(--dot-color);width:8px;height:8px;animation:dot-keys var(--animation);border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.py-status .circle .outline{width:14px;height:14px;animation:outline-keys var(--animation);border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.py-status.ready{color:var(--success);border-color:var(--success-soft);background:var(--success-soft)}.py-status.ready .circle{--dot-color:var(--success)}.py-status.ready .circle .outline{animation:outline-keys-success var(--animation)}.py-status.loading{color:var(--warning)}.py-status.loading .circle{--dot-color:var(--warning)}.py-status.loading .circle .outline{animation:outline-keys-warning var(--animation)}.py-status.error{color:var(--danger);background:var(--danger-soft)}.py-status.error .circle{--dot-color:var(--danger)}.theme-toggle{border:1px solid var(--border);background:var(--surface-2);border-radius:999px;align-items:center;width:54px;height:30px;padding:0 4px;display:flex;position:relative}.theme-toggle .knob{background:var(--surface);border:1px solid var(--border-strong);width:22px;height:22px;color:var(--accent);box-shadow:var(--shadow-sm);border-radius:50%;justify-content:center;align-items:center;transition:transform .22s cubic-bezier(.4,0,.2,1);display:flex;position:absolute}[data-theme=dark] .theme-toggle .knob{transform:translate(24px)}.workspace{flex-direction:column;flex:1;gap:14px;padding:18px;display:flex;overflow-y:auto}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:10px;padding:11px 14px;display:flex}.card-head-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:8px;font-size:12.5px;font-weight:600;display:flex}.card-actions{gap:7px;display:flex}.problem-desc{padding:18px 20px}.editor-card .cm-editor{background:var(--code-bg);font-size:13.5px}.editor-card .cm-content{padding-left:12px}.editor-host{border-radius:0 0 var(--radius) var(--radius);padding:6px 0;overflow:hidden}.cm-editor{height:100%}.cm-editor.cm-focused{outline:none}.cm-scroller{line-height:1.6;font-family:var(--font-mono)!important}.console-card{flex-direction:column;display:flex}.console-body{font-family:var(--font-mono);white-space:pre-wrap;word-break:break-word;max-height:360px;padding:14px 16px;font-size:12.7px;line-height:1.6;overflow:auto}.console-empty{color:var(--text-faint);font-style:italic}.console-stdout{color:var(--text)}.console-stderr{color:var(--danger);margin-top:8px}.console-img{border-radius:var(--radius-sm);border:1px solid var(--border);background:#fff;max-width:100%;margin-top:12px}.console-running{color:var(--text-muted);font-family:var(--font-sans);align-items:center;gap:9px;display:flex}.pkg-banner{border-radius:var(--radius-sm);background:var(--warning-soft);color:var(--text);border:none;align-items:center;gap:12px;margin:12px 14px 0;padding:11px 14px;font-size:13px;display:flex}.pkg-banner .grow{flex:1}.pkg-banner code{font-family:var(--font-mono);color:var(--warning);font-weight:600}.spinner{border:2px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:15px;height:15px;animation:.7s linear infinite spin}.spinner.sm{border-width:2px;width:13px;height:13px}.resizer{cursor:col-resize;background:0 0;flex-shrink:0;width:6px;position:relative}.resizer:after{content:"";border-radius:2px;transition:background .15s;position:absolute;inset:0 2px}.resizer:hover:after,.resizer.active:after{background:var(--accent)}.defense{background:var(--surface);border-left:1px solid var(--border);flex-direction:column;flex-shrink:0;min-width:0;height:100%;display:flex}.defense-head{border-bottom:1px solid var(--border);align-items:center;gap:11px;padding:13px 16px;display:flex}.ai-avatar{background:var(--accent);width:36px;height:36px;color:var(--accent-contrast);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.defense-head-info{flex:1;min-width:0}.defense-head-title{font-size:13.5px;font-weight:650}.defense-head-model{color:var(--text-faint);white-space:nowrap;text-overflow:ellipsis;font-size:11.5px;overflow:hidden}.defense-statusbar{border-bottom:1px solid var(--border);background:var(--surface-2);align-items:center;gap:8px;padding:8px 14px;display:flex}.state-pill{background:var(--surface);border:1px solid var(--border);color:var(--text-muted);border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:550;display:inline-flex}.state-pill .circle{--dot-color:var(--text-faint);--animation:2s ease-in-out infinite;border:solid 2px var(--dot-color);width:12px;height:12px;animation:circle-keys var(--animation);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.state-pill .circle .dot{background:var(--dot-color);width:6px;height:6px;animation:dot-keys var(--animation);border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.state-pill .circle .outline{border-radius:50%;width:12px;height:12px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.state-pill.thinking,.state-pill.executing_tool,.state-pill.finalizing{color:var(--accent);border-color:var(--accent-soft);background:var(--accent-soft)}.state-pill.thinking .circle,.state-pill.executing_tool .circle,.state-pill.finalizing .circle{--dot-color:var(--accent)}.state-pill.thinking .circle .outline,.state-pill.executing_tool .circle .outline,.state-pill.finalizing .circle .outline{animation:outline-keys-accent var(--animation)}.state-pill.init{color:var(--success);border-color:var(--success-soft);background:var(--success-soft)}.state-pill.init .circle{--dot-color:var(--success)}.state-pill.init .circle .outline{animation:outline-keys-success var(--animation)}.state-pill.waiting_for_student{color:var(--warning);background:var(--warning-soft);border-color:color-mix(in srgb, var(--warning) 30%, transparent)}.state-pill.waiting_for_student .circle{--dot-color:var(--warning)}.state-pill.waiting_for_student .circle .outline{animation:outline-keys-warning var(--animation)}.state-pill.done{color:var(--success);background:var(--success-soft);border-color:var(--success-soft)}.state-pill.done .circle{--dot-color:var(--success);animation:none}.state-pill.done .circle .dot{animation:none}.state-pill.failed{color:var(--danger);background:var(--danger-soft);border-color:var(--danger-soft)}.state-pill.failed .circle{--dot-color:var(--danger);animation:none}.state-pill.failed .circle .dot{animation:none}.statusbar-ops{gap:2px;margin-left:auto;display:flex}.chat-stream{flex-direction:column;flex:1;gap:10px;padding:16px 16px 16px 14px;display:flex;overflow-y:auto}.chat-empty{text-align:center;color:var(--text-faint);max-width:300px;margin:auto;padding:30px 24px}.chat-empty h3{color:var(--text);margin:0 0 8px;font-size:14.5px;font-weight:640}.chat-empty p{margin:0;font-size:12.8px;line-height:1.6}.chat-stream.blurred{position:relative;overflow:hidden}.chat-stream.blurred:before{content:"";background:repeating-linear-gradient(45deg, color-mix(in srgb, var(--surface-2) 60%, transparent) 0px, color-mix(in srgb, var(--surface-2) 60%, transparent) 1px, transparent 1px, transparent 6px), repeating-linear-gradient(-45deg, color-mix(in srgb, var(--border) 40%, transparent) 0px, color-mix(in srgb, var(--border) 40%, transparent) 1px, transparent 1px, transparent 6px);opacity:.35;z-index:1;pointer-events:none;position:absolute;inset:0}.chat-stream.blurred:after{content:"";background:color-mix(in srgb, var(--surface) 55%, transparent);z-index:2;pointer-events:none;position:absolute;inset:0}.chat-stream.blurred .chat-empty{z-index:3;position:relative}.msg{flex-direction:column;gap:6px;animation:.22s fadeUp;display:flex}.msg.user{align-items:flex-end}.msg-meta{color:var(--text-faint);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:6px;font-size:11px;font-weight:600;display:flex}.msg-bubble{border-radius:var(--radius);max-width:92%;padding:10px 13px;font-size:13.5px;line-height:1.6}.msg.user .msg-bubble{background:var(--accent);color:var(--accent-contrast);border-bottom-right-radius:4px}[data-theme=light] .msg.user .msg-bubble{color:#1a1a1a;border:1px solid var(--border);background:#fff}[data-theme=dark] .msg.user .msg-bubble{background:var(--surface-3);color:var(--text);border:1px solid var(--border-strong)}.thread-row{padding-left:16px;animation:.2s fadeUp;position:relative}.thread-row:before{content:"";border-left:1px dashed var(--border-strong);position:absolute;top:-8px;bottom:-8px;left:3px}.ai-text{color:var(--text-muted);font-size:13.5px;line-height:1.65}.ai-text p:first-child{margin-top:0}.ai-text p:last-child{margin-bottom:0}.step-pill{border:1px solid var(--border);background:var(--surface);max-width:100%;color:var(--text);text-align:left;border-radius:999px;align-items:center;gap:7px;padding:5px 12px 5px 9px;transition:border-color .15s,background .15s;display:inline-flex}.step-pill:hover{border-color:var(--border-strong);background:var(--surface-2)}.step.err .step-pill{border-color:color-mix(in srgb, var(--danger) 35%, transparent);background:var(--danger-soft)}.step-ico{color:var(--text-muted);flex-shrink:0;align-items:center;display:flex}.step.err .step-ico{color:var(--danger)}.step-label{white-space:nowrap;flex-shrink:0;font-size:13px;font-weight:550}.step-sum{color:var(--text-faint);font-size:12px;font-family:var(--font-mono);white-space:nowrap;text-overflow:ellipsis;min-width:0;overflow:hidden}.step-stat{color:var(--text-faint);flex-shrink:0}.step-stat.err{color:var(--danger)}.step-pill .chev{color:var(--text-faint);flex-shrink:0;transition:transform .18s}.step.open .step-pill .chev{transform:rotate(90deg)}.step-body{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--code-bg);margin-top:8px;overflow:hidden}.divider{color:var(--text-faint);text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:10px;margin:4px 0;font-size:11.5px;font-weight:600;display:flex}.divider:before,.divider:after{content:"";background:var(--border);flex:1;height:1px}.collapse{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);max-width:100%;overflow:hidden}.collapse-head{color:var(--text-muted);text-align:left;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:7px 11px;font-size:12px;font-weight:550;display:flex}.collapse-head:hover{background:var(--surface-3)}.collapse-head .chev{color:var(--text-faint);margin-left:auto;transition:transform .18s}.collapse.open .collapse-head .chev{transform:rotate(90deg)}.collapse-body{padding:0 11px 11px;font-size:12.5px}.thinking-text{color:var(--text-muted);white-space:pre-wrap;border-left:2px solid var(--border-strong);padding-left:10px;font-style:italic;line-height:1.6}.collapse.compact{background:0 0;border:none;margin-bottom:5px;overflow:visible}.collapse.compact .collapse-head{width:auto;color:var(--text-faint);gap:5px;padding:1px 2px;font-size:11.5px;display:inline-flex}.collapse.compact .collapse-head:hover{color:var(--text-muted);background:0 0}.collapse.compact .collapse-head .chev{margin-left:2px}.collapse.compact .collapse-body{padding:4px 0 2px}.tool-card{border:1px solid var(--border);border-radius:var(--radius-sm);max-width:100%;overflow:hidden}.tool-card-head{background:var(--surface-2);text-align:left;width:100%;color:var(--text);border:none;align-items:center;gap:8px;padding:8px 11px;font-size:12px;display:flex}.tool-card-head:hover{background:var(--surface-3)}.tool-ico{background:var(--accent-soft);width:24px;height:24px;color:var(--accent);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.tool-name{font-family:var(--font-mono);font-size:12px;font-weight:600}.tool-arg{color:var(--text-faint);font-family:var(--font-mono);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:11.5px;overflow:hidden}.tool-status{flex-shrink:0;align-items:center;gap:4px;margin-left:auto;display:flex}.tool-card-head .chev{color:var(--text-faint);flex-shrink:0;transition:transform .18s}.tool-card.open .tool-card-head .chev{transform:rotate(90deg)}.tool-card-body{border-top:1px solid var(--border);background:var(--code-bg)}.tool-pre{font-family:var(--font-mono);white-space:pre-wrap;word-break:break-word;color:var(--text-muted);max-height:320px;margin:0;padding:11px 13px;font-size:11.8px;line-height:1.55;overflow:auto}.tool-pre.err{color:var(--danger)}.tool-img{border-top:1px solid var(--border);background:#fff;max-width:100%;display:block}.verdict{border-radius:var(--radius);border:1px solid var(--border);animation:.3s fadeUp;overflow:hidden}.verdict-top{align-items:center;gap:14px;padding:16px;display:flex}.verdict.passed{border-color:color-mix(in srgb, var(--success) 45%, transparent)}.verdict.passed .verdict-top{background:var(--success-soft)}.verdict.failed{border-color:color-mix(in srgb, var(--danger) 45%, transparent)}.verdict.failed .verdict-top{background:var(--danger-soft)}.verdict.needs_revision{border-color:color-mix(in srgb, var(--warning) 45%, transparent)}.verdict.needs_revision .verdict-top{background:var(--warning-soft)}.verdict-icon{color:#fff;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.verdict.passed .verdict-icon{background:var(--success)}.verdict.failed .verdict-icon{background:var(--danger)}.verdict.needs_revision .verdict-icon{background:var(--warning)}.verdict-label{font-size:15px;font-weight:700}.verdict-score{color:var(--text-muted);margin-top:2px;font-size:12.5px}.verdict-score b{color:var(--text);font-size:19px}.verdict-body{background:var(--surface);padding:14px 16px}.thinking-loader{border:1px solid var(--border);background:var(--surface);color:var(--text-muted);border-radius:999px;align-items:center;gap:7px;width:fit-content;margin-top:10px;padding:5px 12px 5px 9px;font-size:13px;font-weight:550;display:inline-flex}.thinking-loader-dots{aspect-ratio:1;background:var(--text-muted);--_m:conic-gradient(#0000 10%, #000), linear-gradient(#000 0 0) content-box;width:14px;-webkit-mask:var(--_m);-webkit-mask:var(--_m);mask:var(--_m);-webkit-mask-composite:source-out;border-radius:50%;flex-shrink:0;padding:2px;animation:1s linear infinite thinking-l3;-webkit-mask-composite:source-out;mask-composite:subtract}@keyframes thinking-l3{to{transform:rotate(1turn)}}.caret:after{content:"▍";color:var(--accent);margin-left:1px;animation:1s step-end infinite blink}.chat-input{border-top:1px solid var(--border);background:var(--surface);padding:12px 14px}.chat-input-box{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-2);flex-direction:column;transition:border-color .15s,box-shadow .15s;display:flex}.chat-input-box:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.chat-input-box textarea{resize:none;color:var(--text);max-height:140px;font-size:13.5px;line-height:1.55;font-family:var(--font-sans);background:0 0;border:none;outline:none;padding:11px 13px 4px}.chat-input-box textarea:disabled{cursor:not-allowed}.chat-input-foot{justify-content:space-between;align-items:center;padding:4px 8px 8px 13px;display:flex}.chat-input-hint{color:var(--text-faint);font-size:11px}.send-btn{background:var(--accent);width:32px;height:32px;color:var(--accent-contrast);border:none;border-radius:8px;justify-content:center;align-items:center;transition:background .15s,opacity .15s;display:flex}.send-btn:hover{background:var(--accent-hover)}.send-btn:disabled{opacity:.4;cursor:not-allowed}.overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:100;background:#080a0e8c;justify-content:center;align-items:center;padding:24px;animation:.16s overlayIn;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);flex-direction:column;width:100%;max-width:600px;max-height:88vh;animation:.2s cubic-bezier(.16,1,.3,1) modalIn;display:flex;overflow:hidden}.modal.wide{max-width:720px}.modal.narrow{max-width:440px}.modal-head{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:16px 20px;display:flex}.modal-head h2{flex:1;margin:0;font-size:15.5px;font-weight:660}.modal-body{padding:20px;overflow-y:auto}.modal-foot{border-top:1px solid var(--border);justify-content:flex-end;gap:9px;padding:14px 20px;display:flex}.tabs{background:var(--surface-2);border-radius:0;gap:4px;margin-bottom:18px;padding:4px;display:flex}.tab{border-radius:var(--radius-sm);height:34px;color:var(--text-muted);background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:7px;font-size:13px;font-weight:550;display:flex}.tab:hover{color:var(--text)}.tab.active{background:var(--surface);color:var(--accent);box-shadow:var(--shadow-sm)}.settings-section{margin-bottom:22px}.settings-section:last-child{margin-bottom:0}.section-title{color:var(--text);align-items:center;gap:8px;margin-bottom:12px;font-size:13px;font-weight:640;display:flex}.section-card{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-2);padding:15px}.form-row{margin-bottom:13px}.form-row:last-child{margin-bottom:0}.key-row{gap:8px;display:flex}.key-row .field{flex:1}.test-result{align-items:center;gap:6px;margin-top:7px;font-size:12px;display:flex}.test-result.ok{color:var(--success)}.test-result.err{color:var(--danger)}.data-ops{grid-template-columns:repeat(3,1fr);gap:9px;display:grid}.pkg-grid{grid-template-columns:repeat(3,1fr);gap:9px;margin-bottom:18px;display:grid}.pkg-card{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);text-align:left;padding:11px 12px;transition:border-color .15s,background .15s}.pkg-card:hover:not(.installed){border-color:var(--border-strong)}.pkg-card.installed{background:var(--success-soft);border-color:#0000}.pkg-card-name{font-family:var(--font-mono);justify-content:space-between;align-items:center;gap:6px;font-size:12.5px;font-weight:600;display:flex}.pkg-card-status{color:var(--text-faint);align-items:center;gap:5px;margin-top:4px;font-size:11px;display:flex}.pkg-card.installed .pkg-card-status{color:var(--success)}.pkg-installed-list{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.pkg-tag{background:var(--surface-2);border:1px solid var(--border);font-size:12px;font-family:var(--font-mono);border-radius:999px;align-items:center;gap:7px;padding:5px 7px 5px 11px;display:inline-flex}.pkg-tag-ops{gap:2px;display:flex}.pkg-tag-op{color:var(--text-faint);background:0 0;border:none;border-radius:5px;justify-content:center;align-items:center;width:20px;height:20px;display:inline-flex}.pkg-tag-op:hover{background:var(--surface-3);color:var(--text)}.pkg-tag-op.del:hover{color:var(--danger)}.type-options{grid-template-columns:1fr 1fr;gap:10px;display:grid}.type-option{border:1px solid var(--border);border-radius:var(--radius);text-align:left;background:var(--surface-2);align-items:flex-start;gap:11px;padding:14px;transition:border-color .15s,background .15s;display:flex}.type-option:hover{border-color:var(--border-strong)}.type-option.active{border-color:var(--accent);background:var(--accent-soft)}.type-option .to-ico{color:var(--text-muted)}.type-option.active .to-ico{color:var(--accent)}.to-title{font-size:13px;font-weight:600}.to-desc{color:var(--text-faint);margin-top:2px;font-size:11.5px;line-height:1.45}.gen-steps{flex-direction:column;gap:4px;max-height:280px;margin-top:6px;display:flex;overflow-y:auto}.gen-step{border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border);align-items:flex-start;gap:10px;padding:9px 11px;font-size:12.5px;animation:.2s fadeUp;display:flex}.gen-step .gs-ico{flex-shrink:0;margin-top:1px;display:flex}.gen-step.ok .gs-ico{color:var(--success)}.gen-step.fail .gs-ico{color:var(--danger)}.gen-step.active .gs-ico{color:var(--accent)}.gs-main{flex:1;min-width:0}.gs-title{color:var(--text);font-weight:550}.gs-detail{color:var(--text-faint);font-size:11.5px;font-family:var(--font-mono);white-space:pre-wrap;word-break:break-word;max-height:90px;margin-top:3px;overflow:auto}.confirm-icon{background:var(--danger-soft);width:44px;height:44px;color:var(--danger);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.confirm-body{align-items:flex-start;gap:14px;padding:22px 20px 6px;display:flex}.confirm-body h3{margin:0 0 6px;font-size:15px;font-weight:640}.confirm-body p{color:var(--text-muted);margin:0;font-size:13px;line-height:1.55}.toast-stack{z-index:200;flex-direction:column;gap:9px;max-width:360px;display:flex;position:fixed;bottom:20px;right:20px}.toast{border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);align-items:center;gap:10px;padding:11px 14px;font-size:13px;animation:.2s fadeUp;display:flex}.toast .t-ico{flex-shrink:0;display:flex}.toast.success .t-ico{color:var(--success)}.toast.error .t-ico{color:var(--danger)}.toast.info .t-ico{color:var(--accent)}.toast-msg{flex:1;line-height:1.45}.splash{background:var(--bg);z-index:300;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex;position:fixed;inset:0}.splash .brand-logo{border-radius:16px;width:56px;height:56px}.muted{color:var(--text-muted)}.faint{color:var(--text-faint)}.spacer{flex:1}.row{align-items:center;gap:8px;display:flex}.hidden-file{display:none}.spin-ico{animation:.8s linear infinite spin}.workzone{flex:1;min-height:0;display:flex;overflow:hidden}.work-scroll{flex-direction:column;flex:1;gap:14px;padding:18px;display:flex;overflow-y:auto}.no-problem{text-align:center;color:var(--text-faint);flex-direction:column;align-items:center;gap:8px;margin:auto;display:flex}.no-problem h2{color:var(--text);margin:8px 0 0;font-size:18px;font-weight:660}.no-problem p{font-size:13px}.btn.sm.ghost{border-color:#0000}.hint-box{border-radius:var(--radius-sm);background:var(--accent-soft);margin-top:14px;padding:11px 14px;font-size:13px;line-height:1.55}.hint-box b{color:var(--accent);margin-right:6px}.hint-md{display:inline}.hint-md p{margin:4px 0 0}.defense-wrap{flex-shrink:0;height:100%;display:flex}.defense{flex:1}.field{background:0 0;border:none;height:auto;margin-bottom:14px;padding:0;display:block}.field:last-child{margin-bottom:0}.field>label{color:var(--text-muted);margin-bottom:6px;font-size:12px;font-weight:550;display:block}.field input,.field select,.field textarea,.field-row input,.field-row select{border:1px solid var(--border);background:var(--surface);width:100%;height:38px;color:var(--text);border-radius:var(--radius-sm);outline:none;padding:0 12px;font-size:13px;transition:border-color .15s,box-shadow .15s}.field select{cursor:pointer}.field input:focus,.field select:focus,.field-row input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.field-row{align-items:center;gap:8px;display:flex}.field-row input{flex:1}.field-ok{color:var(--success);margin-top:7px;font-size:12px;display:inline-block}.field-err{color:var(--danger);margin-top:7px;font-size:12px;display:inline-block}.model-select{flex:1;position:relative}.model-select-trigger{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);width:100%;height:38px;color:var(--text);cursor:pointer;justify-content:space-between;align-items:center;gap:6px;padding:0 12px;font-family:inherit;font-size:13px;transition:border-color .15s;display:flex}.model-select-trigger:hover:not(:disabled){border-color:var(--border-strong)}.model-select.open .model-select-trigger{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.model-select.disabled .model-select-trigger{opacity:.45;cursor:not-allowed;background:var(--surface-2)}.model-select-value{text-align:left;text-overflow:ellipsis;white-space:nowrap;color:var(--text);flex:1;overflow:hidden}.model-select.disabled .model-select-value{color:var(--text-muted)}.model-select-arrow{color:var(--text-muted);flex-shrink:0;transition:transform .15s}.model-select.open .model-select-arrow{transform:rotate(180deg)}.model-select-dropdown{z-index:200;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);max-height:220px;padding:4px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto}.model-select-option{width:100%;color:var(--text);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:5px;align-items:center;gap:8px;padding:7px 10px;font-family:inherit;font-size:13px;transition:background .1s;display:flex}.model-select-option:hover{background:var(--surface-2)}.model-select-option.selected{background:var(--accent-soft);color:var(--accent)}.option-check{color:var(--accent);flex-shrink:0}.modal-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:100;background:#080a0e8c;justify-content:center;align-items:center;padding:24px;animation:.16s overlayIn;display:flex;position:fixed;inset:0}.modal-title{flex:1;align-items:center;gap:9px;font-size:15.5px;font-weight:660;display:flex}.settings-modal{max-width:600px}.gen-modal{max-width:540px}.settings-block{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-2);margin-bottom:16px;padding:16px}.settings-block:last-child{margin-bottom:0}.settings-block-title{color:var(--text);align-items:center;gap:8px;margin-bottom:13px;font-size:13px;font-weight:640;display:flex}.settings-hint{color:var(--text-faint);margin:-6px 0 16px;font-size:12px;line-height:1.5}.py-warn{border-radius:var(--radius-sm);background:var(--warning-soft);border:1px solid color-mix(in srgb, var(--warning) 30%, transparent);color:var(--text);margin-bottom:16px;padding:11px 14px;font-size:12.5px}.btn.xs{gap:4px;height:26px;padding:0 9px;font-size:11.5px}.pkg-card{flex-direction:column;gap:9px;display:flex}.pkg-card-name{display:block}.pkg-card-actions{align-items:center;gap:8px;display:flex}.pkg-ok{color:var(--success)}.link-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-size:11.5px;font-weight:550}.link-btn:hover{text-decoration:underline}.link-btn:disabled{opacity:.5;cursor:not-allowed}.pkg-tags{flex-wrap:wrap;gap:8px;display:flex}.tag-op{color:var(--text-faint);cursor:pointer;background:0 0;border:none;border-radius:5px;justify-content:center;align-items:center;width:20px;height:20px;display:inline-flex}.tag-op:hover{background:var(--surface-3);color:var(--text)}.tag-op.del:hover{color:var(--danger)}.type-cards{grid-template-columns:1fr 1fr;gap:10px;display:grid}.type-card{border:1px solid var(--border);border-radius:var(--radius);text-align:left;background:var(--surface-2);cursor:pointer;flex-direction:column;gap:4px;padding:13px;transition:border-color .15s,background .15s;display:flex}.type-card:hover{border-color:var(--border-strong)}.type-card.active{background:var(--accent-soft);border-color:#0000}.type-card-label{color:var(--text);font-size:13px;font-weight:600}.type-card.active .type-card-label{color:var(--accent)}.type-card-desc{color:var(--text-faint);font-size:11.5px;line-height:1.45}.gen-progress{flex-direction:column;gap:5px;max-height:260px;margin-top:6px;display:flex;overflow-y:auto}.gen-step{flex-direction:row;align-items:center}.gen-step.ok{color:var(--text)}.gen-step.ok>svg{color:var(--success)}.gen-step.fail,.gen-step.fail>svg{color:var(--danger)}.gen-step.active{color:var(--accent);border-color:var(--accent-soft);background:var(--accent-soft)}.gen-step>span{flex:1;min-width:0}.gen-error{border-radius:var(--radius-sm);background:var(--danger-soft);border:1px solid color-mix(in srgb, var(--danger) 30%, transparent);color:var(--danger);align-items:center;gap:9px;margin-top:12px;padding:11px 13px;font-size:12.5px;display:flex}.defense-error{border-radius:var(--radius);background:var(--danger-soft);border:1px solid color-mix(in srgb, var(--danger) 32%, transparent);gap:10px;margin:0 14px 12px;padding:12px 14px;display:flex}.defense-error-icon{color:var(--danger);flex-shrink:0;margin-top:1px}.defense-error-body{flex-direction:column;flex:1;gap:7px;min-width:0;display:flex}.defense-error-title{color:var(--danger);font-size:13px;font-weight:650}.defense-error-hint{color:var(--text-muted);font-size:12.5px;line-height:1.5}.defense-error-detail{font-family:var(--font-mono);color:var(--text-muted);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);white-space:pre-wrap;word-break:break-word;max-height:120px;margin:0;padding:8px 10px;font-size:11px;line-height:1.5;overflow:auto}.defense-error .btn.sm{align-self:flex-start}
