@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@500;700&family=Manrope:wght@400;600;700;800&display=swap";.confirm-modal-backdrop[data-v-5964294c]{position:fixed;top:0;right:0;bottom:0;left:0;background:color-mix(in srgb,#000000,transparent 45%);display:flex;align-items:center;justify-content:center;z-index:1200;padding:1rem}.confirm-modal[data-v-5964294c]{background:color-mix(in srgb,var(--backgroundSecondary),var(--panel) 20%);border:1px solid var(--border);border-radius:12px;padding:1rem;max-width:420px;width:min(100%,420px);text-align:center}.confirm-modal h3[data-v-5964294c]{margin:0 0 .5rem;font-size:1rem;font-family:JetBrains Mono,monospace}.confirm-modal p[data-v-5964294c]{margin:0 0 1rem;font-size:.82rem;line-height:1.45;color:var(--textSecondary)}.confirm-actions[data-v-5964294c]{display:flex;gap:.55rem;justify-content:center}.btn-secondary[data-v-5964294c],.btn-primary[data-v-5964294c]{font-family:JetBrains Mono,monospace;font-size:.7rem;padding:.38rem .72rem;border-radius:999px;cursor:pointer}.btn-secondary[data-v-5964294c]{border:1px solid var(--border);background:var(--backgroundSecondary);color:var(--text)}.btn-primary[data-v-5964294c]{border:1px solid color-mix(in srgb,var(--primary),var(--backgroundSecondary) 40%);background:color-mix(in srgb,var(--primary),var(--backgroundSecondary) 10%);color:#fff}.grading-modal-backdrop[data-v-87ffc2ac]{position:fixed;top:0;right:0;bottom:0;left:0;background:color-mix(in srgb,#000000,transparent 38%);display:flex;align-items:center;justify-content:center;z-index:1200;padding:1rem}.grading-modal[data-v-87ffc2ac]{position:relative;width:min(100%,760px);max-height:86vh;overflow:hidden;display:flex;flex-direction:column;border:1px solid var(--border);border-radius:14px;background:color-mix(in srgb,var(--backgroundSecondary),var(--panel) 20%)}.close-btn[data-v-87ffc2ac]{position:absolute;top:.55rem;right:.55rem;width:1.7rem;height:1.7rem;border:1px solid var(--border);border-radius:999px;background:var(--backgroundSecondary);color:var(--textSecondary);display:grid;place-items:center;padding:0;cursor:pointer}.grading-loading[data-v-87ffc2ac],.grading-error[data-v-87ffc2ac]{min-height:260px;display:grid;place-content:center;justify-items:center;gap:.5rem;padding:1rem;color:var(--textSecondary);font-family:JetBrains Mono,monospace;font-size:.76rem;text-align:center}.grading-error[data-v-87ffc2ac]{color:var(--danger)}.spin[data-v-87ffc2ac]{animation:spin-87ffc2ac .9s linear infinite}.grading-header[data-v-87ffc2ac]{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.9rem 3rem .9rem 1rem;border-bottom:1px solid var(--border)}.rating-section[data-v-87ffc2ac]{display:flex;align-items:center;gap:.35rem}.rating-label[data-v-87ffc2ac]{font-family:JetBrains Mono,monospace;font-size:.84rem;font-weight:700}.score-section[data-v-87ffc2ac]{display:inline-flex;align-items:baseline;gap:.1rem}.score-earned[data-v-87ffc2ac]{font-family:JetBrains Mono,monospace;font-size:1.35rem;font-weight:800}.score-divider[data-v-87ffc2ac],.score-max[data-v-87ffc2ac]{color:var(--textSecondary)}.grading-body[data-v-87ffc2ac]{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);overflow-y:auto}.feedback-column[data-v-87ffc2ac]{background:var(--backgroundSecondary);padding:.9rem 1rem}.feedback-column h4[data-v-87ffc2ac]{margin:0 0 .55rem;display:inline-flex;align-items:center;gap:.32rem;font-family:JetBrains Mono,monospace;font-size:.72rem;text-transform:uppercase}.feedback-column ul[data-v-87ffc2ac]{margin:0;padding-left:1rem;display:grid;gap:.42rem}.feedback-column li[data-v-87ffc2ac]{color:var(--textSecondary);font-size:.8rem;line-height:1.45}.feedback-column.strengths h4[data-v-87ffc2ac]{color:var(--success)}.feedback-column.weaknesses h4[data-v-87ffc2ac]{color:var(--danger)}.empty-state[data-v-87ffc2ac]{margin:0;color:var(--textSecondary);font-style:italic;font-size:.78rem}.grading-footer[data-v-87ffc2ac]{display:flex;justify-content:flex-end;gap:.55rem;padding:.8rem 1rem;border-top:1px solid var(--border);background:color-mix(in srgb,var(--backgroundSecondary),var(--panel) 10%)}.btn-secondary[data-v-87ffc2ac],.btn-primary[data-v-87ffc2ac]{border-radius:999px;font-family:JetBrains Mono,monospace;font-size:.7rem;padding:.36rem .7rem;cursor:pointer}.btn-secondary[data-v-87ffc2ac]{border:1px solid var(--border);background:var(--backgroundSecondary);color:var(--text)}.btn-primary[data-v-87ffc2ac]{border:1px solid color-mix(in srgb,var(--primary),var(--backgroundSecondary) 40%);background:color-mix(in srgb,var(--primary),var(--backgroundSecondary) 10%);color:#fff;display:inline-flex;align-items:center;gap:.3rem}@media(max-width:720px){.grading-body[data-v-87ffc2ac]{grid-template-columns:1fr}}@keyframes spin-87ffc2ac{0%{transform:rotate(0)}to{transform:rotate(360deg)}}:root{--background: #f4f0ec;--backgroundSecondary: #faf8f5;--panel: #ece7e2;--text: #2a2425;--textSecondary: #7c7172;--primary: #c87068;--accent: #a8865e;--success: #4a8c65;--warning: #b89040;--danger: #b54545;--border: #dbd5cf;--grid: rgba(200, 112, 104, .06);--glow: rgba(200, 112, 104, .1);--bg-elevated: #e4dfd9;--text-tertiary: #a8a09a;--text-disabled: #cec8c2;--accent-primary-hover: #af5c54;--border-hover: #cac3bc;--border-focus: #c87068;--difficulty-easy-bg: rgba(74, 140, 101, .1);--difficulty-easy-text: #3a7c54;--difficulty-medium-bg: rgba(184, 144, 64, .11);--difficulty-medium-text: #96761e;--difficulty-hard-bg: rgba(181, 69, 69, .1);--difficulty-hard-text: #9c3838;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--text-xs: 12px;--text-sm: 14px;--text-base: 16px;--text-lg: 18px;--text-xl: 20px;--text-2xl: 24px;--text-3xl: 30px;--text-4xl: 36px;--text-5xl: 48px;--transition-fast: .15s ease;--transition-normal: .2s ease}*{box-sizing:border-box}html,body,#app{margin:0;min-height:100%}body{font-family:Manrope,Segoe UI,sans-serif;font-size:var(--text-base);line-height:1.5;color:var(--text);background:var(--background)}a{color:inherit;text-decoration:none}.shell-width{width:min(1310px,calc(100% - 2rem));margin-inline:auto}.homepage{display:flex;flex-direction:column;min-height:100vh}.top-nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:var(--space-4) 0;border-bottom:1px solid var(--border)}.logo{display:inline-flex;align-items:center;gap:var(--space-2);font-weight:800;font-size:var(--text-base);letter-spacing:-.01em}.logo__glyph{font-family:JetBrains Mono,monospace;color:var(--primary);font-size:var(--text-sm);font-weight:700}.logo__beta{display:inline-flex;align-items:center;padding:2px 8px;border-radius:9999px;background:var(--primary);color:#fff;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;line-height:1.4}.top-nav__links{display:inline-flex;gap:var(--space-6);color:var(--textSecondary);font-weight:600;font-size:var(--text-sm)}.top-nav__links a{transition:color var(--transition-fast)}.top-nav__links a:hover{color:var(--text)}.top-nav__right{display:flex;align-items:center;gap:var(--space-4)}.hamburger{display:none;border:1px solid var(--border);background:transparent;color:var(--textSecondary);border-radius:var(--radius-md);padding:var(--space-2);width:36px;height:36px;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.hamburger:hover{border-color:var(--border-hover);color:var(--text)}.theme-toggle{border:1px solid var(--border);background:transparent;color:var(--textSecondary);border-radius:var(--radius-md);padding:var(--space-2);display:inline-flex;align-items:center;justify-content:center;font-family:inherit;font-size:0;cursor:pointer;transition:border-color var(--transition-fast),color var(--transition-fast);width:36px;height:36px;overflow:hidden;flex-shrink:0}.theme-toggle:hover{border-color:var(--border-hover);color:var(--text)}.theme-toggle svg{width:18px;height:18px;display:block}.hero{padding:var(--space-16) 0 var(--space-12)}.hero__inner{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-12);align-items:center}.hero__content{display:flex;flex-direction:column;gap:var(--space-5)}.hero__eyebrow{font-family:JetBrains Mono,monospace;font-size:var(--text-xs);font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--primary)}.hero__title{font-size:clamp(2rem,4.5vw,var(--text-5xl));font-weight:800;line-height:1.08;letter-spacing:-.03em;margin:0}.hero__subtitle{font-size:var(--text-lg);color:var(--textSecondary);line-height:1.6;max-width:48ch;margin:0}.hero__actions{display:flex;gap:var(--space-3);margin-top:var(--space-2)}.hero__stats{list-style:none;margin:0;padding:0;display:inline-flex;gap:var(--space-4);flex-wrap:nowrap;color:var(--textSecondary);font-family:JetBrains Mono,monospace;font-size:var(--text-xs);white-space:nowrap}.hero__stats strong{color:var(--text);margin-right:4px}.hero__waitlist{margin-top:var(--space-8);display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-3);width:100%}.hero__waitlist-label{color:var(--textSecondary);font-size:var(--text-base);margin:0}.hero__waitlist .waitlist-form{max-width:520px}.hero__waitlist .waitlist-count,.hero__waitlist .waitlist-message{font-size:var(--text-sm)}.hero__visual{display:flex;justify-content:center}.browser-mockup{width:100%;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;background:var(--backgroundSecondary)}.browser-mockup__bar{display:flex;align-items:center;gap:6px;padding:10px 14px;background:var(--panel);border-bottom:1px solid var(--border)}.browser-mockup__dot{width:10px;height:10px;border-radius:50%;background:var(--border-hover)}.browser-mockup__url{flex:1;margin-left:8px;height:24px;border-radius:var(--radius-sm);background:var(--backgroundSecondary);border:1px solid var(--border);display:flex;align-items:center;padding:0 10px;font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text-tertiary)}.browser-mockup img{width:100%;display:block}.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-md);border:1px solid transparent;padding:var(--space-3) var(--space-5);font-family:inherit;font-size:var(--text-sm);font-weight:700;cursor:pointer;text-decoration:none;transition:background-color var(--transition-fast),border-color var(--transition-fast)}.btn--primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn--primary:hover{background:var(--accent-primary-hover);border-color:var(--accent-primary-hover)}.btn--secondary{background:transparent;color:var(--textSecondary);border-color:var(--border)}.btn--secondary:hover{color:var(--text);border-color:var(--border-hover);background:var(--panel)}.how{padding:var(--space-16) 0;border-top:1px solid var(--border)}.how__header{text-align:center;margin-bottom:var(--space-12)}.how__header .eyebrow{margin-bottom:var(--space-3)}.how__header h2{margin:0}.how__flow{margin:0;padding:0;list-style:none;display:grid;gap:var(--space-12)}.how__step{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(250px,1fr);gap:var(--space-8);align-items:center;min-width:0}.how__step:nth-child(2n){grid-template-columns:minmax(250px,1fr) minmax(0,1.35fr)}.how__step:nth-child(2n) .how__shot{order:2}.how__step:nth-child(2n) .how__copy{order:1}.how__copy{display:flex;flex-direction:column;gap:var(--space-3)}.how__title-row{display:flex;align-items:baseline;gap:var(--space-3);flex-wrap:nowrap}.how__title-row h3{display:inline}.how__step-number{font-family:JetBrains Mono,monospace;font-size:var(--text-xs);font-weight:700;color:var(--text-tertiary);letter-spacing:.04em}.how__copy h3{margin:0;font-size:var(--text-xl);font-weight:700}.how__copy p{margin:0;color:var(--textSecondary);font-size:var(--text-base);line-height:1.6}.how__shot{width:100%;aspect-ratio:16 / 10;min-width:0;max-height:340px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--backgroundSecondary);display:grid;place-items:center;overflow:hidden}.how__shot img{width:100%;height:100%;max-width:100%;object-fit:cover;object-position:center top;display:block}.eyebrow{text-transform:uppercase;font-family:JetBrains Mono,monospace;font-weight:700;letter-spacing:.06em;font-size:var(--text-xs);color:var(--primary);margin:0}.section-heading{display:grid;gap:var(--space-3);text-align:center;margin-bottom:var(--space-10)}h1,h2,h3,p{margin:0}h1{font-size:clamp(2rem,4.5vw,var(--text-5xl));line-height:1.08;letter-spacing:-.03em;font-weight:800}h2{font-size:var(--text-2xl);font-weight:700;line-height:1.25;letter-spacing:-.02em}h3{font-size:var(--text-lg);font-weight:700}.problems{padding:var(--space-16) 0;border-top:1px solid var(--border)}.problems>.section-heading,.problems>.table-wrap,.problems>.problems__action{max-width:860px;margin-inline:auto}.problems--compact .section-heading h2{font-size:clamp(1.1rem,2vw,1.45rem)}.table-wrap{position:relative;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--backgroundSecondary);overflow-x:auto}table{width:100%;border-collapse:collapse;min-width:500px}th,td{text-align:left;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border)}th{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;font-family:JetBrains Mono,monospace;color:var(--textSecondary);font-weight:700}tbody tr:last-child td{border-bottom:0}.problem-row{cursor:pointer;transition:background-color var(--transition-fast)}.problem-row:hover td{background:var(--panel)}.problem-row:focus-visible{outline:2px solid var(--border-focus);outline-offset:-2px}.problems__action{display:flex;justify-content:center;margin-top:var(--space-6)}.problems--compact table{min-width:0}.problems--compact th,.problems--compact td{padding:var(--space-2) var(--space-3)}.problems--compact td{font-size:var(--text-sm)}.difficulty-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:9999px;font-size:var(--text-xs);font-weight:700;line-height:1;white-space:nowrap}.difficulty-badge--easy{background:var(--difficulty-easy-bg);color:var(--difficulty-easy-text)}.difficulty-badge--medium{background:var(--difficulty-medium-bg);color:var(--difficulty-medium-text)}.difficulty-badge--hard{background:var(--difficulty-hard-bg);color:var(--difficulty-hard-text)}.waitlist-section{padding:var(--space-16) 0;border-top:1px solid var(--border)}.waitlist-section__inner{max-width:560px;margin:0 auto;text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.waitlist-section__inner h2{margin:0}.waitlist-section__inner>p{color:var(--textSecondary);font-size:var(--text-sm);margin:0}.waitlist-form{width:100%;max-width:480px;display:grid;grid-template-columns:1fr auto;gap:var(--space-3);margin-top:var(--space-2)}.waitlist-form input{width:100%;border:1px solid var(--border);background:var(--panel);color:var(--text);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font:inherit;font-size:var(--text-sm);transition:border-color var(--transition-fast)}.waitlist-form input::placeholder{color:var(--text-tertiary)}.waitlist-form input:focus-visible{outline:none;border-color:var(--border-focus)}.waitlist-form input.is-invalid{border-color:var(--danger)}.waitlist-form .btn:disabled{opacity:.6;cursor:not-allowed}.waitlist-count{font-size:var(--text-sm);color:var(--textSecondary);font-weight:600}.waitlist-count.is-muted{color:var(--text-tertiary);font-weight:400}.waitlist-message{font-size:var(--text-sm)}.waitlist-message.is-success{color:var(--success)}.waitlist-message.is-error{color:var(--danger)}.waitlist-message.is-info{color:var(--textSecondary)}.waitlist-inline{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);text-align:center;padding:var(--space-8) 0;border-top:1px solid var(--border)}.waitlist-inline__label{color:var(--textSecondary);font-size:var(--text-sm);margin:0}.waitlist-inline .waitlist-form{max-width:480px}.site-footer{border-top:1px solid var(--border);padding:var(--space-8) 0;display:flex;align-items:center;justify-content:space-between;gap:var(--space-4)}.site-footer__brand{font-weight:700;font-size:var(--text-sm)}.site-footer small{color:var(--text-tertiary);font-size:var(--text-xs)}.problems-directory{min-height:100vh;display:flex;flex-direction:column}.problems-directory__main{flex:1;padding:var(--space-10) 0}.problems-directory__main .problems{padding-top:0;border-top:0}.tooltip{position:absolute;z-index:2147483647;transform:translate3d(0,-100%,0);border:1px solid var(--primary);background:var(--primary);color:#fff;font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.02em;line-height:1.4;padding:6px 10px;border-radius:6px;pointer-events:none;white-space:pre-line;max-width:230px;overflow-wrap:break-word}.tooltip--fixed{position:fixed}.tooltip--below{transform:translate3d(0,10px,0)}.waitlist-popup{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;padding:1rem}.waitlist-popup__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0009}.waitlist-popup__panel{position:relative;width:min(480px,100%);background:var(--backgroundSecondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-6);padding-top:var(--space-4);display:grid;gap:var(--space-4)}.waitlist-popup__close{justify-self:end;width:1.35rem;height:1.35rem;border:1px solid var(--border);border-radius:999px;background:var(--backgroundSecondary);color:var(--textSecondary);display:grid;place-items:center;padding:0;cursor:pointer;transition:border-color var(--transition-fast),color var(--transition-fast)}.waitlist-popup__close:hover{border-color:var(--border-hover);color:var(--text)}.waitlist-popup__eyebrow{text-transform:uppercase;font-family:JetBrains Mono,monospace;font-size:11px;color:var(--primary);letter-spacing:.06em}@media(max-width:980px){.hero__inner{grid-template-columns:1fr;gap:var(--space-10);text-align:center}.hero__content{align-items:center}.hero__subtitle{max-width:60ch}.hero__actions{justify-content:center}.hero__visual{display:none}.how__step,.how__step:nth-child(2n){grid-template-columns:1fr;gap:var(--space-4)}.how__step:nth-child(2n) .how__shot,.how__step:nth-child(2n) .how__copy{order:initial}.how__shot{max-height:none}}@media(max-width:640px){.shell-width{width:min(1310px,calc(100% - 1.5rem))}.hero{padding:var(--space-10) 0 var(--space-8)}.hero__title{font-size:clamp(1.75rem,7vw,2.5rem)}.hero__subtitle{font-size:var(--text-base)}.top-nav{position:relative;flex-wrap:nowrap;gap:var(--space-3)}.hamburger{display:inline-flex}.top-nav__links{display:none;position:absolute;top:100%;right:0;z-index:50;flex-direction:column;gap:0;background:var(--backgroundSecondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-2) 0;min-width:160px;box-shadow:0 8px 24px color-mix(in srgb,var(--text),transparent 88%);font-size:var(--text-sm)}.top-nav__links.is-open{display:flex}.top-nav__links a{padding:var(--space-2) var(--space-4)}.top-nav__links a:hover{background:var(--panel)}.waitlist-form{grid-template-columns:1fr}.problems,.how{padding:var(--space-8) 0}.site-footer{flex-direction:column;align-items:flex-start;gap:var(--space-2)}}.problem-page{height:100vh;display:grid;grid-template-rows:auto 1fr;background:color-mix(in srgb,var(--backgroundSecondary),var(--panel) 26%);color:var(--text);overflow:hidden;position:relative}.problem-top-nav{width:100%;border-bottom:1px solid var(--border)}.problem-top-nav__inner{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:1rem;padding-top:.85rem;padding-bottom:.85rem}.problem-top-nav__inner .top-nav__links{justify-self:center}.problem-workspace{min-height:0;display:grid;grid-template-columns:auto 1fr;overflow:hidden}.problem-toolbar{border-right:1px solid var(--border);background:color-mix(in srgb,var(--backgroundSecondary),var(--panel) 34%);position:relative;width:320px;height:100%;min-height:0;padding:.45rem .42rem;overflow:visible;transition:width .22s ease,padding .22s ease}.problem-toolbar.is-collapsed{width:44px;padding:.75rem .3rem}.problem-toolbar.is-delete-target-active{border-right-color:color-mix(in srgb,var(--primary),white 28%)}.toolbar-delete-overlay{position:absolute;top:.45rem;right:.42rem;bottom:.45rem;left:.42rem;z-index:8;border:1px dashed color-mix(in srgb,var(--primary),#ffffff 42%);border-radius:12px;background:color-mix(in srgb,var(--primary),transparent 50%);pointer-events:none;display:grid;place-items:center}.toolbar-delete-overlay__label{color:#fff;font-family:JetBrains Mono,monospace;font-size:1.42rem;font-weight:900;letter-spacing:.07em;text-transform:uppercase;-webkit-text-stroke:1px color-mix(in srgb,var(--primary),#3d1f18 58%);text-shadow:0 2px 4px color-mix(in srgb,var(--primary),#3d1f18 64%),0 0 14px color-mix(in srgb,#ffffff,transparent 58%)}.toolbar-resizer{position:absolute;top:0;right:-4px;width:10px;height:100%;cursor:col-resize;z-index:7}.toolbar-resizer:hover{background:color-mix(in srgb,var(--primary),var(--backgroundSecondary) 70%)}.toolbar-collapse-btn{position:absolute;top:50%;right:0;transform:translate(50%,-50%);width:46px;height:46px;border:1px solid var(--border);border-radius:999px;background:var(--backgroundSecondary);font-family:JetBrains Mono,monospace;font-size:.9rem;font-weight:700;line-height:1;cursor:pointer;z-index:6;color:color-mix(in srgb,var(--primary),var(--text) 28%);transition:background-color .12s ease,border-color .12s ease,color .12s ease}.toolbar-collapse-btn:hover{background:color-mix(in srgb,var(--primary),var(--backgroundSecondary) 90%);border-color:color-mix(in srgb,var(--primary),var(--backgroundSecondary) 26%);color:color-mix(in srgb,var(--primary),var(--text) 18%)}.problem-page.is-resizing-sidebar,.problem-page.is-resizing-sidebar *{cursor:col-resize!important;-webkit-user-select:none;user-select:none}.problem-page.is-resizing-sidebar .problem-toolbar{transition:none}.toolbar-content{display:grid;grid-template-rows:auto 1fr;gap:.38rem;height:100%;min-height:0;transition:opacity .16s ease}.toolbar-content.is-hidden{opacity:0;pointer-events:none}.toolbar-group{display:grid;gap:.45rem}.toolbar-group--tabs{grid-template-columns:1fr 1fr;padding-bottom:.28rem;border-bottom:1px solid var(--border)}.toolbar-tab{width:100%;min-height:30px;border:1px solid var(--border);border-radius:8px;background:color-mix(in srgb,var(--backgroundSecondary),var(--panel) 44%);font-family:JetBrains Mono,monospace;font-size:.69rem;text-transform:uppercase;letter-spacing:.06em;color:var(--textSecondary);cursor:pointer;transition:border-color .12s ease,background-color .12s ease,color .12s ease}.toolbar-tab-wrap{display:block}.toolbar-tab-wrap:has(.toolbar-tab:disabled){cursor:not-allowed}.toolbar-tab.is-active{border-color:color-mix(in srgb,var(--primary),var(--backgroundSecondary) 35%);background:color-mix(in srgb,var(--primary),var(--backgroundSecondary) 86%);color:color-mix(in srgb,var(--primary),var(--text) 20%)}.toolbar-tab:disabled{opacity:.48;cursor:not-allowed;color:color-mix(in srgb,var(--textSecondary),var(--backgroundSecondary) 18%);pointer-events:none}.problem-toolbar.is-collapsed .toolbar-group--tabs{grid-template-columns:1fr}.problem-toolbar.is-collapsed .toolbar-tab{min-height:34px;font-size:.66rem;padding:0}.problem-toolbar.is-compact-toolbox .toolbar-group--tabs{gap:.28rem}.problem-toolbar.is-compact-toolbox .toolbar-tab{min-height:26px;font-size:.6rem;letter-spacing:.04em}.problem-toolbar.is-compact-toolbox .toolbox-section{gap:.14rem}.problem-toolbar.is-compact-toolbox .toolbox-section__title{font-size:.56rem}.problem-toolbar.is-compact-toolbox .toolbox-grid{gap:.12rem}.problem-toolbar.is-compact-toolbox .toolbox-item{border-radius:7px}.problem-toolbar.is-compact-toolbox .toolbox-item--with-label{gap:.08rem;padding:.14rem .1rem .12rem}.problem-toolbar.is-compact-toolbox .toolbox-item img{width:26px;height:26px}.problem-toolbar.is-compact-toolbox .design-tool-icon{width:18px;height:18px}.problem-toolbar.is-compact-toolbox .toolbox-item-label{font-size:.5rem;line-height:1.1;letter-spacing:.02em}.problem-toolbar.is-compact-toolbox .toolbox-tag{font-size:.5rem;padding:.04rem .16rem}.toolbox-list{align-content:start;display:grid;gap:.22rem;overflow-y:auto;padding-right:.05rem}.toolbox-list--sections{align-content:start}.toolbox-section{display:grid;gap:.18rem}.toolbox-section__title{margin:0;font-family:JetBrains Mono,monospace;font-size:.64rem;text-transform:uppercase;letter-spacing:.08em;color:var(--textSecondary)}.toolbox-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.16rem}.toolbox-grid--design{grid-template-columns:repeat(4,minmax(0,1fr))}.toolbox-grid--tooltip-anchor{position:relative;overflow:visible}.toolbox-separator{width:100%;border:0;border-top:1px solid var(--border);margin:.12rem 0 .1rem}.toolbox-item{border:1px solid var(--border);border-radius:9px;background:color-mix(in srgb,var(--backgroundSecondary),var(--panel) 48%);aspect-ratio:1 / .76;min-height:0;display:grid;place-items:center;position:relative;color:var(--text);cursor:pointer;padding:0}.toolbox-item--design{aspect-ratio:1 / .76;cursor:pointer}.toolbox-item--with-label{align-content:center;justify-items:center;gap:.14rem;padding:.2rem .15rem .18rem}.toolbox-item:active{cursor:pointer}.toolbox-item.is-selected{border-color:color-mix(in srgb,var(--primary),var(--backgroundSecondary) 30%);background:color-mix(in srgb,var(--primary),var(--backgroundSecondary) 86%);color:color-mix(in srgb,var(--primary),var(--text) 20%)}.toolbox-item img{width:34px;height:34px}.design-tool-icon{width:24px;height:24px;pointer-events:none}.toolbox-item-label{max-width:100%;font-family:JetBrains Mono,monospace;font-size:.62rem;line-height:1.2;text-transform:uppercase;letter-spacing:.04em;color:color-mix(in srgb,var(--textSecondary),var(--text) 28%);text-align:center;white-space:normal}.toolbox-tag{position:absolute;bottom:4px;right:4px;border-radius:6px;background:color-mix(in srgb,var(--primary),var(--backgroundSecondary) 15%);color:var(--backgroundSecondary);font-family:JetBrains Mono,monospace;font-size:.58rem;padding:.08rem .24rem}.problem-stage{position:relative;height:100%;min-height:0;padding:0}.problem-panel{border:0;border-radius:0;background:transparent;padding:.25rem .56rem 1.2rem .3rem;height:100%;min-height:0;overflow-y:hidden;overscroll-behavior:contain}.problem-panel.is-scrollable{overflow-y:auto}.problem-header{position:static;padding-bottom:0;margin-bottom:.4rem;background:transparent}.problem-panel h2{margin:0 0 1rem;font-size:clamp(1.55rem,2.6vw,2.25rem);line-height:1.04;letter-spacing:-.02em;max-width:22ch}.problem-title-row{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem;flex-wrap:wrap}.problem-title-row h2{margin-bottom:.2rem}.problem-state{color:var(--textSecondary)}.problem-state--error{color:var(--danger)}.problem-intro{max-width:68ch;margin:0 0 1.05rem;display:grid;gap:.78rem}.problem-intro-paragraph{margin:0;color:color-mix(in srgb,var(--text),var(--textSecondary) 35%);font-size:1.04rem;line-height:1.52}.problem-intro-raw{margin:0 0 1.05rem;max-width:68ch;color:color-mix(in srgb,var(--text),var(--textSecondary) 35%);font-size:1.04rem;line-height:1.52;white-space:pre-line}.problem-start-section{margin:0 0 1.12rem;padding:0 0 .96rem;display:grid;gap:.72rem}.problem-start-intro{margin:0;color:var(--textSecondary);line-height:1.5}.problem-start-intro--after-requirements{margin-top:.92rem}.problem-start-btn{width:fit-content;justify-self:center;border:1px solid color-mix(in srgb,var(--primary),var(--backgroundSecondary) 28%);border-radius:999px;background:color-mix(in srgb,var(--primary),var(--backgroundSecondary) 8%);color:#fff;font-family:JetBrains Mono,monospace;font-size:.9rem;font-weight:700;letter-spacing:.01em;padding:.58rem 1.28rem;cursor:pointer}.problem-start-btn:hover:not(:disabled){background:color-mix(in srgb,var(--primary),#5a2e24 18%)}.problem-start-btn:disabled{opacity:.64;cursor:default}.problem-pill-row{display:flex;flex-wrap:wrap;gap:.42rem;margin:0 0 .9rem}.problem-pill-row--meta{margin-top:-.46rem}.problem-pill{display:inline-flex;align-items:center;border-radius:999px;border:1px solid color-mix(in srgb,var(--primary),var(--backgroundSecondary) 45%);background:color-mix(in srgb,var(--primary),var(--backgroundSecondary) 88%);color:color-mix(in srgb,var(--primary),var(--text) 24%);padding:.2rem .58rem;font-family:JetBrains Mono,monospace;font-size:.67rem;line-height:1.1;letter-spacing:.01em}.problem-pill--difficulty-easy{border-color:color-mix(in srgb,var(--success),var(--backgroundSecondary) 35%);background:color-mix(in srgb,var(--success),var(--backgroundSecondary) 87%);color:color-mix(in srgb,var(--success),var(--text) 28%)}.problem-pill--difficulty-medium{border-color:color-mix(in srgb,var(--warning),var(--backgroundSecondary) 35%);background:color-mix(in srgb,var(--warning),var(--backgroundSecondary) 87%);color:color-mix(in srgb,var(--warning),var(--text) 28%)}.problem-pill--difficulty-hard{border-color:color-mix(in srgb,var(--danger),var(--backgroundSecondary) 35%);background:color-mix(in srgb,var(--danger),var(--backgroundSecondary) 87%);color:color-mix(in srgb,var(--danger),var(--text) 28%)}.problem-pill--difficulty-title{font-size:1.18rem;line-height:1;padding:.32rem .86rem;border-width:2px}.problem-pill-row--tags .problem-pill{border-color:color-mix(in srgb,var(--accent),var(--backgroundSecondary) 36%);background:color-mix(in srgb,var(--accent),var(--backgroundSecondary) 86%);color:color-mix(in srgb,var(--accent),var(--text) 22%)}.problem-section{padding-top:.9rem;border-top:1px solid color-mix(in srgb,var(--border),var(--backgroundSecondary) 20%);margin-top:.6rem}.problem-panel h3{margin:0 0 .4rem;font-size:1.08rem;letter-spacing:-.01em;color:var(--text)}.problem-panel p,.problem-panel li{color:var(--textSecondary);line-height:1.5;font-size:1.08rem}.problem-panel ul,.requirements-list{margin:0;padding-left:1.35rem;display:grid;gap:.34rem}.requirements-fade-enter-active{transition:opacity .22s ease,transform .22s ease;transition-delay:var(--req-delay, 0ms)}.requirements-fade-enter-from{opacity:0;transform:translateY(6px)}.requirements-fade-enter-to{opacity:1;transform:translateY(0)}.requirements-section-fade-enter-active{transition:opacity .18s ease}.requirements-section-fade-enter-from{opacity:0}.requirements-section-fade-enter-to{opacity:1}.problem-panel strong{color:var(--text);font-weight:800}.timer-chip{border:1px solid var(--border);border-radius:999px;background:color-mix(in srgb,var(--backgroundSecondary),var(--panel) 58%);padding:.32rem .62rem;font-family:JetBrains Mono,monospace;font-size:.76rem}.stage-controls{position:absolute;top:.8rem;right:.8rem;z-index:5;display:flex;align-items:center;gap:.4rem;flex-wrap:nowrap}.nav-back-btn{display:inline-flex;align-items:center;gap:.32rem;border:1px solid var(--border);border-radius:999px;background:color-mix(in srgb,var(--backgroundSecondary),var(--panel) 44%);color:var(--text);font-family:JetBrains Mono,monospace;font-size:.68rem;line-height:1;padding:.34rem .58rem;cursor:pointer}.zoom-controls{display:inline-grid;grid-template-columns:auto auto auto;align-items:center;gap:.25rem;border:1px solid var(--border);border-radius:999px;background:color-mix(in srgb,var(--backgroundSecondary),var(--panel) 44%);padding:.14rem .24rem;font-family:JetBrains Mono,monospace;font-size:.68rem}.zoom-controls button{width:1.35rem;height:1.35rem;border:1px solid var(--border);border-radius:999px;background:var(--backgroundSecondary);font-family:inherit;font-weight:700;line-height:1;cursor:pointer}.history-controls{display:inline-grid;grid-template-columns:auto auto;align-items:center;gap:.28rem;border:1px solid var(--border);border-radius:999px;background:color-mix(in srgb,var(--backgroundSecondary),var(--panel) 44%);padding:.14rem .22rem}.history-controls button{width:1.35rem;height:1.35rem;border:1px solid var(--border);border-radius:999px;background:var(--backgroundSecondary);display:grid;place-items:center;padding:0;line-height:0;color:var(--text);cursor:pointer}.history-controls button:disabled{opacity:.4;cursor:not-allowed}.feedback-btn{display:inline-flex;align-items:center;gap:.3rem;border:1px solid var(--border);border-radius:999px;background:color-mix(in srgb,var(--primary),var(--backgroundSecondary) 88%);color:color-mix(in srgb,var(--primary),var(--text) 22%);font-family:JetBrains Mono,monospace;font-size:.66rem;line-height:1;padding:.34rem .58rem;cursor:pointer}.feedback-btn-wrap{display:inline-flex}.feedback-btn-wrap:has(.feedback-btn:disabled){cursor:not-allowed}.feedback-btn:disabled{opacity:.48;cursor:not-allowed;pointer-events:none}.submit-btn{display:inline-flex;align-items:center;gap:.3rem;border:1px solid var(--border);border-radius:999px;background:color-mix(in srgb,var(--accent),var(--backgroundSecondary) 86%);color:color-mix(in srgb,var(--accent),var(--text) 20%);font-family:JetBrains Mono,monospace;font-size:.66rem;line-height:1;padding:.34rem .58rem;cursor:pointer}.submit-btn:disabled{opacity:.48;cursor:not-allowed;pointer-events:none}.show-solution-btn{display:inline-flex;align-items:center;gap:.3rem;border:1px solid var(--border);border-radius:999px;background:color-mix(in srgb,var(--success),var(--backgroundSecondary) 88%);color:color-mix(in srgb,var(--success),var(--text) 24%);font-family:JetBrains Mono,monospace;font-size:.66rem;line-height:1;padding:.34rem .58rem;cursor:pointer}.view-result-btn{display:inline-flex;align-items:center;gap:.3rem;border:1px solid var(--border);border-radius:999px;background:color-mix(in srgb,var(--primary),var(--backgroundSecondary) 90%);color:color-mix(in srgb,var(--primary),var(--text) 22%);font-family:JetBrains Mono,monospace;font-size:.66rem;line-height:1;padding:.34rem .58rem;cursor:pointer}.feedback-panel{position:absolute;top:3.4rem;right:.8rem;z-index:5;width:min(380px,calc(100% - 1.6rem));border:1px solid var(--border);border-radius:12px;background:color-mix(in srgb,var(--backgroundSecondary),var(--panel) 32%);overflow:visible;box-shadow:0 8px 24px color-mix(in srgb,var(--text),transparent 86%)}.feedback-panel__close-btn{position:absolute;top:0;right:0;transform:translate(50%,-50%);width:1.34rem;height:1.34rem;border:1px solid var(--border);border-radius:999px;background:var(--backgroundSecondary);color:var(--textSecondary);display:inline-flex;align-items:center;justify-content:center;padding:0;line-height:0;cursor:pointer;z-index:2}.feedback-panel__close-btn svg{display:block}.feedback-panel__close-btn:hover{border-color:color-mix(in srgb,var(--primary),var(--backgroundSecondary) 35%);color:color-mix(in srgb,var(--primary),var(--text) 20%)}.feedback-panel__body{max-height:min(60vh,520px);overflow:auto;padding:.92rem .72rem .62rem}.feedback-panel__error{font-family:JetBrains Mono,monospace;font-size:.72rem;color:var(--danger);padding-right:1.6rem}.feedback-panel__empty{margin:0;color:var(--textSecondary);font-size:.8rem;line-height:1.35}.feedback-panel__section+.feedback-panel__section{margin-top:.52rem;padding-top:.52rem;border-top:1px solid color-mix(in srgb,var(--border),var(--backgroundSecondary) 20%)}.feedback-panel__section h3{font-family:JetBrains Mono,monospace;font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.32rem}.feedback-panel__section ul{margin:0;padding-left:1.05rem;display:grid;gap:.22rem}.feedback-panel__section li{color:var(--textSecondary);font-size:.8rem;line-height:1.34}.feedback-suggestion-text{margin:0;color:var(--textSecondary);font-size:.8rem;line-height:1.35;min-height:4.6rem}.feedback-suggestion-controls{margin-top:.18rem;display:flex;align-items:center;justify-content:space-between;gap:.34rem}.feedback-suggestion-controls button{border:1px solid var(--border);border-radius:999px;background:var(--backgroundSecondary);color:var(--text);font-family:JetBrains Mono,monospace;font-size:.62rem;line-height:1;padding:.22rem .48rem;cursor:pointer}.feedback-suggestion-controls button:disabled{opacity:.42;cursor:not-allowed}.feedback-suggestion-controls span{font-family:JetBrains Mono,monospace;font-size:.66rem;color:var(--textSecondary)}.canvas-shell{position:relative;height:100%;border-left:1px solid var(--border);background:color-mix(in srgb,var(--backgroundSecondary),var(--panel) 40%);overflow:hidden;cursor:default}.canvas-shell.is-pointer-mode{cursor:url("data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20width='24'%20height='24'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%232f6df6'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3e%3cpath%20d='M4.037%204.688a.495.495%200%200%201%20.651-.651l16%206.5a.5.5%200%200%201-.063.947l-6.124%201.58a2%202%200%200%200-1.438%201.435l-1.579%206.126a.5.5%200%200%201-.947.063z'/%3e%3c/svg%3e") 4 4,pointer}.canvas-shell.is-hand-mode{cursor:grab}.canvas-shell.is-panning{cursor:grabbing}.canvas-shell.is-arrow-mode{cursor:crosshair}.canvas-shell.is-erase-mode{cursor:url("data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20width='24'%20height='24'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%232f6df6'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3e%3cpath%20d='M21%2021H8a2%202%200%200%201-1.42-.587l-3.994-3.999a2%202%200%200%201%200-2.828l10-10a2%202%200%200%201%202.829%200l5.999%206a2%202%200%200%201%200%202.828L12.834%2021'/%3e%3cpath%20d='m5.082%2011.09%208.828%208.828'/%3e%3c/svg%3e") 6 18,pointer}.canvas-shell.is-erase-mode .canvas-node,.canvas-shell.is-erase-mode .connection-endpoint,.canvas-shell.is-erase-mode .connection-hitline,.canvas-shell.is-erase-mode .node-anchor{cursor:url("data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20width='24'%20height='24'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%232f6df6'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3e%3cpath%20d='M21%2021H8a2%202%200%200%201-1.42-.587l-3.994-3.999a2%202%200%200%201%200-2.828l10-10a2%202%200%200%201%202.829%200l5.999%206a2%202%200%200%201%200%202.828L12.834%2021'/%3e%3cpath%20d='m5.082%2011.09%208.828%208.828'/%3e%3c/svg%3e") 6 18,pointer}.board-layer{position:absolute;top:0;left:0;background:linear-gradient(var(--grid) 1px,transparent 1px) 0 0 / 28px 28px,linear-gradient(90deg,var(--grid) 1px,transparent 1px) 0 0 / 28px 28px,var(--backgroundSecondary)}.board-grid{position:absolute;top:0;left:0}.canvas-edges{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.canvas-edges line{stroke:color-mix(in srgb,var(--primary),#3d1f18 24%);stroke-width:2.2}.connection-line--selected{stroke:color-mix(in srgb,var(--accent),#6b4028 24%);stroke-width:2.8}.connection-hitline{stroke:transparent;stroke-width:14}.canvas-edges marker path{fill:color-mix(in srgb,var(--primary),#3d1f18 24%)}.canvas-edge-draft{stroke-dasharray:6 5}.eraser-preview{position:absolute;border:2px solid color-mix(in srgb,var(--accent),#1f2024 28%);border-radius:50%;background:color-mix(in srgb,var(--accent),transparent 82%);box-shadow:0 0 0 1px color-mix(in srgb,var(--panel),#fff 8%);transform:translate(-50%,-50%);pointer-events:none;z-index:14}.canvas-node{position:absolute;width:126px;height:92px;border:1px solid color-mix(in srgb,var(--primary),white 42%);border-radius:14px;background:#fff;display:grid;justify-items:center;gap:.42rem;padding:.6rem;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:none}.canvas-node img{width:32px;height:32px;pointer-events:none;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.canvas-node h3{font-size:.72rem;font-family:JetBrains Mono,monospace;text-transform:uppercase;letter-spacing:.04em;pointer-events:none;-webkit-user-select:none;user-select:none}.canvas-node-note-btn{position:absolute;top:6px;right:6px;width:20px;height:20px;border:1px solid color-mix(in srgb,var(--primary),#3d1f18 30%);border-radius:999px;background:color-mix(in srgb,var(--backgroundSecondary),#ffffff 24%);color:color-mix(in srgb,var(--primary),#3d1f18 12%);padding:0;display:grid;place-items:center;opacity:0;transform:scale(.92);transition:opacity .12s ease,transform .12s ease,background-color .12s ease}.canvas-node:hover .canvas-node-note-btn,.canvas-node-note-btn:focus-visible{opacity:1;transform:scale(1)}.canvas-node-note-btn:hover{background:color-mix(in srgb,var(--primary),var(--backgroundSecondary) 72%)}.canvas-node-note-input{position:absolute;left:6px;right:6px;top:calc(100% + 6px);min-height:18px;border:1px solid color-mix(in srgb,var(--primary),var(--backgroundSecondary) 45%);border-radius:5px;background:var(--backgroundSecondary);color:var(--text);font-family:JetBrains Mono,monospace;font-size:.5rem;line-height:1.2;padding:2px 4px;overflow:hidden;resize:none}.canvas-node-note-input::placeholder{color:color-mix(in srgb,var(--textSecondary),var(--backgroundSecondary) 14%)}.canvas-node-note-input--readonly{margin:0;white-space:pre-line;pointer-events:none;-webkit-user-select:none;user-select:none}.canvas-shell.is-hand-mode .canvas-node{cursor:grab}.canvas-shell.is-hand-mode .canvas-node:active{cursor:grabbing}.canvas-shell.is-pointer-mode .canvas-node,.canvas-shell.is-pointer-mode .connection-endpoint,.canvas-shell.is-pointer-mode .connection-hitline,.canvas-shell.is-pointer-mode .node-anchor{cursor:url("data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20width='24'%20height='24'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%232f6df6'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3e%3cpath%20d='M4.037%204.688a.495.495%200%200%201%20.651-.651l16%206.5a.5.5%200%200%201-.063.947l-6.124%201.58a2%202%200%200%200-1.438%201.435l-1.579%206.126a.5.5%200%200%201-.947.063z'/%3e%3c/svg%3e") 4 4,pointer}.canvas-node--selected{border-color:color-mix(in srgb,var(--accent),#6b4028 25%)}.canvas-node--dragging{opacity:0}.canvas-node--ghost{position:fixed;z-index:2147483646;pointer-events:none;opacity:.96}.node-anchor{position:absolute;width:9px;height:9px;border:1px solid color-mix(in srgb,var(--primary),#3d1f18 30%);border-radius:999px;background:#fff;padding:0;cursor:crosshair}.node-anchor--top{top:-4.5px;left:calc(50% - 4.5px)}.node-anchor--right{top:calc(50% - 4.5px);right:-4.5px}.node-anchor--bottom{bottom:-4.5px;left:calc(50% - 4.5px)}.node-anchor--left{top:calc(50% - 4.5px);left:-4.5px}.connection-endpoint{fill:color-mix(in srgb,var(--primary),white 80%);stroke:color-mix(in srgb,var(--primary),#3d1f18 20%);stroke-width:1.5;cursor:crosshair}.connection-endpoint--selected{fill:color-mix(in srgb,var(--accent),white 80%);stroke:color-mix(in srgb,var(--accent),#6b4028 25%)}.canvas-note{position:absolute;margin:0;font-family:JetBrains Mono,monospace;font-size:.65rem;color:color-mix(in srgb,var(--textSecondary),#5a4028 18%);border-bottom:1px dashed color-mix(in srgb,var(--border),#c0a080 35%);padding-bottom:.06rem}.board-zoom-controls{position:absolute;right:.8rem;top:.8rem;z-index:6;display:inline-grid;grid-template-columns:auto auto auto;align-items:center;gap:.25rem;border:1px solid var(--border);border-radius:999px;background:color-mix(in srgb,var(--backgroundSecondary),var(--panel) 44%);padding:.14rem .24rem;font-family:JetBrains Mono,monospace;font-size:.68rem}.board-zoom-controls button{width:1.35rem;height:1.35rem;border:1px solid var(--border);border-radius:999px;background:var(--backgroundSecondary);font-family:inherit;font-weight:700;line-height:1;cursor:pointer}.solution-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;background:color-mix(in srgb,#000000,transparent 32%);display:flex;align-items:center;justify-content:center;padding:1rem}.node-note-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;background:color-mix(in srgb,#000000,transparent 42%);display:flex;align-items:center;justify-content:center;padding:1rem}.node-note-modal{width:min(520px,100%);border:1px solid var(--border);border-radius:12px;background:color-mix(in srgb,var(--backgroundSecondary),var(--panel) 22%);box-shadow:0 12px 34px color-mix(in srgb,var(--text),transparent 84%);padding:.9rem;display:grid;gap:.6rem}.node-note-modal__header{display:flex;align-items:center;justify-content:space-between;gap:.7rem}.node-note-modal__header h3{margin:0;font-size:.84rem;font-family:JetBrains Mono,monospace;text-transform:uppercase;letter-spacing:.03em}.node-note-modal__close{width:1.6rem;height:1.6rem;border:1px solid var(--border);border-radius:999px;background:var(--backgroundSecondary);color:var(--textSecondary);display:grid;place-items:center;cursor:pointer;padding:0}.node-note-modal__hint{margin:0;color:var(--textSecondary);font-size:.76rem}.node-note-modal__field{width:100%;border:1px solid var(--border);border-radius:8px;background:var(--backgroundSecondary);color:var(--text);font-family:JetBrains Mono,monospace;font-size:.72rem;line-height:1.45;padding:.6rem .7rem;resize:vertical}.node-note-modal__footer{display:flex;justify-content:flex-end;gap:.45rem}.node-note-modal__btn{border-radius:999px;font-family:JetBrains Mono,monospace;font-size:.68rem;padding:.34rem .72rem;cursor:pointer}.node-note-modal__btn--secondary{border:1px solid var(--border);background:var(--backgroundSecondary);color:var(--text)}.node-note-modal__btn--primary{border:1px solid color-mix(in srgb,var(--primary),var(--backgroundSecondary) 42%);background:color-mix(in srgb,var(--primary),var(--backgroundSecondary) 10%);color:#fff}.solution-modal{width:min(1400px,100%);height:min(900px,100%);border:1px solid var(--border);border-radius:14px;background:color-mix(in srgb,var(--backgroundSecondary),var(--panel) 30%);box-shadow:0 10px 30px color-mix(in srgb,var(--text),transparent 84%);overflow:hidden;display:flex;flex-direction:column}.solution-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.7rem;padding:.84rem .95rem;border-bottom:1px solid var(--border)}.header-content{display:grid;gap:.25rem}.header-content h2{font-size:1rem;font-family:JetBrains Mono,monospace}.solution-summary{color:var(--textSecondary);font-size:.82rem;line-height:1.4}.close-btn{width:1.9rem;height:1.9rem;border:1px solid var(--border);border-radius:999px;background:var(--backgroundSecondary);color:var(--textSecondary);display:grid;place-items:center;cursor:pointer;padding:0}.solution-modal-body{flex:1;min-height:0;position:relative}.loading-state,.error-state{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-content:center;justify-items:center;gap:.44rem;color:var(--textSecondary);font-family:JetBrains Mono,monospace;font-size:.75rem}.error-state{color:var(--danger)}.error-state button{border:1px solid var(--border);border-radius:999px;background:var(--backgroundSecondary);color:var(--text);font-family:JetBrains Mono,monospace;font-size:.66rem;padding:.24rem .6rem;cursor:pointer}.spin{animation:spin .9s linear infinite}.solution-modal-footer{border-top:1px solid var(--border);display:flex;flex-direction:column;min-height:0}.notes-toggle{width:100%;border:0;display:flex;align-items:center;gap:.36rem;background:transparent;color:var(--textSecondary);font-family:JetBrains Mono,monospace;font-size:.72rem;padding:.55rem .9rem;cursor:pointer}.notes-toggle svg{transition:transform .15s ease}.notes-toggle .rotated{transform:rotate(180deg)}.notes-content{padding:0 .9rem .75rem;max-height:min(42vh,340px);overflow-y:auto;overscroll-behavior:contain}.notes-line{margin:0;font-size:.82rem;line-height:1.5;color:var(--textSecondary)}.notes-line+.notes-line{margin-top:.56rem}.notes-line--heading{margin-top:.12rem;color:color-mix(in srgb,var(--text),var(--textSecondary) 25%)}.notes-line--labeled strong{color:color-mix(in srgb,var(--primary),var(--text) 40%);font-family:JetBrains Mono,monospace;font-size:.74rem;letter-spacing:.02em;margin-right:.28rem}.notes-line code{font-family:JetBrains Mono,monospace;font-size:.74rem;background:color-mix(in srgb,var(--panel),var(--backgroundSecondary) 25%);border:1px solid var(--border);border-radius:4px;padding:.02rem .2rem}.modal-enter-active,.modal-leave-active{transition:opacity .14s ease}.modal-enter-from,.modal-leave-to{opacity:0}.expand-enter-active,.expand-leave-active{transition:all .16s ease;overflow:hidden}.expand-enter-from,.expand-leave-to{opacity:0;max-height:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.drawer{position:absolute;background:var(--backgroundSecondary);border:1px solid var(--border);z-index:5;transition:transform .22s ease}.drawer h2{margin-bottom:.7rem}.drawer p,.drawer li{color:var(--textSecondary)}@media(max-width:900px){.problem-toolbar{width:260px;padding:.8rem .65rem}.problem-toolbar.is-collapsed{width:40px}}@media(max-width:640px){.problem-toolbar{width:210px}.problem-toolbar.is-collapsed{width:38px}.toolbox-item{min-height:50px}.toolbox-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.toolbox-section__title{font-size:.62rem}.toolbar-collapse-btn{width:48px;height:48px}.canvas-shell{height:100%}.stage-controls{flex-wrap:wrap;justify-content:flex-end;row-gap:.34rem}.feedback-panel{top:4.5rem;max-height:min(54vh,400px)}}
