@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap);:root{--ink:#1e1b16;--ink-soft:#5a5246;--ink-faint:#8e8678;--paper:#faf6ef;--paper-2:#efe7d7;--paper-3:#e8dfc9;--w-peach:#e8a87c;--w-amber:#e8b450;--w-coral:#c45a3a;--w-tan:#b89070;--w-cream:#f5d9b8;--good:#7a8a52;--sky:#6a9aaa;--plum:#8a5a7a;--line:var(--ink)}*,:after,:before{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;background:#efe7d7;background:var(--paper-2);color:#1e1b16;color:var(--ink);font-family:Inter,system-ui,sans-serif;font-size:13px;letter-spacing:-.005em;line-height:1.45;margin:0}.App{flex-direction:column;height:100vh}.App,.App-body{display:flex;overflow:hidden}.App-body{flex:1 1;flex-direction:column;min-height:0}.sk-box{background:#faf6ef;background:var(--paper);border:1.4px solid #1e1b16;border:1.4px solid var(--ink);border-radius:12px 8px 14px 9px/8px 14px 9px 12px}.sk-box.shadow{box-shadow:3px 4px 0 #1e1b16;box-shadow:3px 4px 0 var(--ink)}.sk-box.tight{border-radius:6px 4px 8px 5px/4px 8px 5px 6px}.sk-box.paper2{background:#efe7d7;background:var(--paper-2)}.sk-box.cream{background:#f5d9b8;background:var(--w-cream)}.sk-box.peach{background:#e8a87c;background:var(--w-peach)}.sk-box.amber{background:#e8b450;background:var(--w-amber)}.sk-box.coral{background:#c45a3a;background:var(--w-coral);color:#fff}.sk-box.tan{background:#b89070;background:var(--w-tan);color:#fff}.sk-box.locked{background-image:repeating-linear-gradient(45deg,#0000 0 6px,#1e1b162e 6px 7px);opacity:.7}.sk-box:hover{box-shadow:4px 5px 0 #1e1b16;box-shadow:4px 5px 0 var(--ink);transform:translate(-1px,-2px);transition:transform .15s,box-shadow .15s}.sk-pill{align-items:center;background:#faf6ef;background:var(--paper);border:1.4px solid #1e1b16;border:1.4px solid var(--ink);border-radius:18px;display:inline-flex;font-size:11px;font-weight:500;gap:4px;padding:2px 9px;white-space:nowrap}.sk-pill.amber{background:#e8b450;background:var(--w-amber)}.sk-pill.coral{background:#c45a3a;background:var(--w-coral);border-color:#c45a3a;border-color:var(--w-coral);color:#fff}.sk-pill.cream{background:#f5d9b8;background:var(--w-cream)}.sk-pill.peach{background:#e8a87c;background:var(--w-peach)}.sk-pill.tan{background:#b89070;background:var(--w-tan);color:#fff}.sk-btn{align-items:center;background:#faf6ef;background:var(--paper);border:1.4px solid #1e1b16;border:1.4px solid var(--ink);border-radius:10px 7px 12px 8px/7px 12px 8px 10px;box-shadow:2px 3px 0 #1e1b16;box-shadow:2px 3px 0 var(--ink);color:#1e1b16;color:var(--ink);cursor:pointer;display:inline-flex;font-size:12px;font-weight:600;gap:4px;padding:5px 12px;text-decoration:none;transition:transform .1s,box-shadow .1s;white-space:nowrap}.sk-btn:hover{box-shadow:3px 4px 0 #1e1b16;box-shadow:3px 4px 0 var(--ink);transform:translate(-1px,-1px)}.sk-btn:active{box-shadow:0 0 0 #1e1b16;box-shadow:0 0 0 var(--ink);transform:translate(2px,3px)}.sk-btn.primary{background:#c45a3a;background:var(--w-coral);border-color:#1e1b16;border-color:var(--ink);color:#fff}.sk-btn.ghost{background:#0000;border-color:#0000;box-shadow:none}.sk-btn.ghost:hover{background:#efe7d7;background:var(--paper-2);box-shadow:none}.sk-anno{color:#8e8678;color:var(--ink-faint);font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.sk-tab{border:1.4px solid #0000;border-radius:8px;color:#5a5246;color:var(--ink-soft);cursor:pointer;font-size:12px;font-weight:500;padding:5px 12px;transition:all .15s}.sk-tab:hover{background:#efe7d7;background:var(--paper-2);color:#1e1b16;color:var(--ink)}.sk-tab.active{background:#faf6ef;background:var(--paper);border-color:#1e1b16;border-color:var(--ink)}.sk-avatar,.sk-tab.active{color:#1e1b16;color:var(--ink);font-weight:700}.sk-avatar{background:#e8a87c;background:var(--w-peach);border:1.4px solid #1e1b16;border:1.4px solid var(--ink);border-radius:50%;flex-shrink:0}.sk-avatar,.sk-coin{align-items:center;display:inline-flex;justify-content:center}.sk-coin{background:#e8b450;background:var(--w-amber);border:1px solid #1e1b16;border:1px solid var(--ink);border-radius:50%;font-size:9px;font-weight:700;height:14px;width:14px}.mono{font-family:JetBrains Mono,monospace}.scroll-y{overflow-y:auto}.sk-hatch{background-image:repeating-linear-gradient(45deg,#0000 0 6px,#1e1b162e 6px 7px)}.topbar{background:var(--paper);border-bottom:1.6px solid var(--ink);gap:12px;height:52px;justify-content:space-between;padding:0 18px}.topbar,.topbar-brand{align-items:center;display:flex;flex-shrink:0}.topbar-brand{color:inherit;gap:10px;text-decoration:none}.topbar-brand-name{color:var(--ink);font-size:16px;font-weight:700;letter-spacing:-.02em;line-height:1}.topbar-brand-sub{color:var(--ink-faint);font-family:JetBrains Mono,monospace;font-size:9px;margin-top:2px}.topbar-stats{align-items:center;display:flex;flex-wrap:nowrap;gap:6px}.topbar-avatar{align-items:center;background:var(--w-peach);border:1.4px solid var(--ink);border-radius:50%;color:var(--ink);cursor:pointer;display:inline-flex;font-size:13px;font-weight:700;height:30px;justify-content:center;transition:transform .1s,box-shadow .1s;width:30px}.topbar-avatar:hover{box-shadow:2px 2px 0 var(--ink);transform:translate(-1px,-1px)}.topbar-logout{background:#0000;border:1.4px solid var(--ink);border-radius:8px;color:var(--ink-soft);cursor:pointer;font-family:inherit;font-size:11px;padding:3px 10px;transition:background .1s}.ide-container,.topbar-logout:hover{background:var(--paper-2)}.ide-container{display:flex;flex:1 1;flex-direction:column;font-family:Inter,system-ui,sans-serif;min-height:0;overflow:hidden;position:relative}.ide-subheader{align-items:center;background:var(--paper);border-bottom:1.4px dashed var(--ink);display:flex;flex-shrink:0;gap:8px;padding:8px 14px}.ide-problem-select{background:var(--paper);border:1.4px solid var(--ink);border-radius:8px;color:var(--ink);cursor:pointer;flex:1 1;font-family:inherit;font-size:12px;max-width:260px;padding:3px 8px}.ide-problem-select:focus{border-color:var(--w-amber);outline:none}.ide-lang-tabs{background:var(--paper-2);border-bottom:1.4px solid var(--ink);display:flex;flex-shrink:0;gap:2px;padding:0 14px}.ide-lang-tab{background:#0000;border:none;border-bottom:2.5px solid #0000;color:var(--ink-soft);cursor:pointer;font-family:inherit;font-size:12px;font-weight:500;margin-bottom:-1px;padding:6px 14px;transition:color .15s,border-color .15s}.ide-lang-tab:hover{color:var(--ink)}.ide-lang-tab.active{border-bottom-color:var(--w-coral);color:var(--w-coral);font-weight:700}.ide-body{border-bottom:1.4px solid var(--ink);display:flex;flex:1 1;min-height:0}.ide-prompt{background:var(--paper);display:flex;flex-direction:column;gap:10px;height:100%;overflow-y:auto;padding:12px 14px}.ide-description{color:var(--ink-soft);font-size:13px;line-height:1.6;margin:0}.ide-anno-sub{color:var(--ink-faint);font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.ide-example{background:var(--paper-2);border:1.2px solid var(--ink);border-left:3px solid var(--w-amber);border-radius:6px 4px 8px 5px/4px 8px 5px 6px;color:var(--ink-soft);display:flex;flex-direction:column;font-size:11px;gap:3px;padding:8px 10px}.ide-example,.ide-example code{font-family:JetBrains Mono,monospace}.ide-example code{background:var(--paper-3);border-radius:3px;color:var(--ink);font-size:10px;padding:1px 4px}.ide-label{color:var(--ink-soft);font-weight:700;margin-right:4px}.ide-explanation{color:var(--ink-faint);font-size:10px;font-style:italic;margin-top:2px}.ide-editor-col{background:var(--paper);display:flex;flex-direction:column;height:100%;overflow:hidden}.ide-file-tabs{align-items:center;background:var(--paper-2);border-bottom:1.4px solid var(--ink);display:flex;flex-shrink:0;gap:6px;padding:4px 10px}.ide-editor-wrapper,.ide-test-pane{flex:1 1;min-height:0;overflow:hidden}.ide-test-pane{background:var(--paper-2);display:flex;flex-direction:column}.sk-split-gutter{background:var(--ink);flex-shrink:0;position:relative;touch-action:none;transition:background .15s}.sk-split-gutter.horizontal{cursor:col-resize;width:6px}.sk-split-gutter.vertical{cursor:row-resize;height:6px}.sk-split-gutter:active,.sk-split-gutter:hover{background:var(--w-amber)}.sk-split-gutter.horizontal:after{background-size:4px 6px;height:24px;left:1px;top:50%;transform:translateY(-50%);width:4px}.sk-split-gutter.horizontal:after,.sk-split-gutter.vertical:after{background-image:radial-gradient(var(--paper) 1px,#0000 1.4px);content:"";opacity:.7;pointer-events:none;position:absolute}.sk-split-gutter.vertical:after{background-size:6px 4px;height:4px;left:50%;top:1px;transform:translateX(-50%);width:24px}.ide-test-header{align-items:center;background:var(--paper);border-bottom:1px solid var(--paper-3);display:flex;flex-shrink:0;gap:6px;padding:6px 10px}.ide-test-scroll{flex:1 1;overflow-y:auto;padding:8px 12px}.ide-coach{align-items:flex-end;bottom:172px;display:flex;gap:6px;pointer-events:none;position:absolute;right:14px;z-index:10}.ide-coach-bubble{background:var(--w-cream);border:1.4px solid var(--ink);border-radius:12px 8px 14px 9px/8px 14px 9px 12px;box-shadow:2px 3px 0 var(--ink);color:var(--ink);font-size:11px;line-height:1.45;max-width:180px;padding:8px 10px}::-webkit-scrollbar{height:5px;width:5px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:var(--paper-3);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--w-tan)}.auth-container{align-items:center;background:linear-gradient(160deg,var(--paper-2) 0,var(--paper-3) 100%);display:flex;justify-content:center;min-height:100vh;padding:20px}.auth-box{background:var(--paper);border:1.6px solid var(--ink);border-radius:12px 8px 14px 9px/8px 14px 9px 12px;box-shadow:4px 5px 0 var(--ink);max-width:420px;padding:36px 40px;width:100%}.auth-box h1{color:var(--ink);font-size:22px;font-weight:700;letter-spacing:-.02em;margin:0 0 6px;text-align:center}.auth-box .subtitle{color:var(--ink-soft);font-size:12px;margin:0 0 18px;text-align:center}.auth-box form{display:flex;flex-direction:column;gap:10px;margin-top:12px}.auth-box label{color:var(--ink-soft);font-size:11px;font-weight:600;letter-spacing:.04em;margin-bottom:-4px;text-transform:uppercase}.auth-box input{background:var(--paper-2);border:1.4px solid var(--ink);border-radius:8px;color:var(--ink);font-family:inherit;font-size:13px;padding:10px 12px;transition:border-color .15s}.auth-box input:focus{border-color:var(--w-amber);outline:none}.auth-box button.primary{background:var(--w-coral);border:1.4px solid var(--ink);border-radius:10px 7px 12px 8px/7px 12px 8px 10px;box-shadow:2px 3px 0 var(--ink);color:#fff;cursor:pointer;font-family:inherit;font-size:13px;font-weight:600;margin-top:6px;padding:10px;transition:transform .1s,box-shadow .1s}.auth-box button.primary:hover:not(:disabled){box-shadow:3px 4px 0 var(--ink);transform:translate(-1px,-1px)}.auth-box button.primary:active{box-shadow:0 0 0 var(--ink);transform:translate(2px,3px)}.auth-box button.primary:disabled{cursor:not-allowed;opacity:.55}.auth-box button.link{background:none;border:none;color:var(--w-coral);cursor:pointer;font-family:inherit;font-size:12px;padding:0;text-decoration:underline}.auth-footer{color:var(--ink-soft);margin-top:18px}.auth-footer,.auth-message{font-size:12px;text-align:center}.auth-message{border-radius:6px;margin-top:12px;padding:8px 12px}.auth-message.success{background:#7a8a5226;border:1px solid var(--good);color:var(--good)}.auth-message.error{background:#c45a3a1f;border:1px solid var(--w-coral);color:var(--w-coral)}.handle-status{color:var(--ink-faint);font-family:JetBrains Mono,monospace;font-size:11px;min-height:16px}.handle-status.available{color:var(--good)}.handle-status.invalid,.handle-status.taken{color:var(--w-coral)}.auth-divider{align-items:center;color:var(--ink-faint);display:flex;font-size:10px;gap:8px;letter-spacing:.08em;margin:14px 0 6px;text-transform:uppercase}.auth-divider:after,.auth-divider:before{background:var(--ink-faint);content:"";flex:1 1;height:1px;opacity:.5}
/*# sourceMappingURL=main.34bd7b43.css.map*/