@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;position:relative}.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-nav{align-items:center;display:flex;flex:1 1;gap:2px;margin-left:14px}.topbar-nav-link{align-items:center;background:#0000;border:1.4px solid #0000;border-radius:8px;color:var(--ink-soft);cursor:pointer;display:inline-flex;font-family:inherit;font-size:12.5px;font-weight:600;gap:6px;padding:6px 10px;text-decoration:none;transition:background .12s,color .12s,border-color .12s}.topbar-nav-link:hover{background:var(--paper-2);color:var(--ink)}.topbar-nav-link.active{background:var(--w-cream);border-color:var(--ink);color:var(--ink)}.topbar-nav-link.soon{cursor:not-allowed;opacity:.55}.topbar-nav-link.soon:hover{background:#0000;color:var(--ink-soft)}.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}.topbar-logout:hover{background:var(--paper-2)}.topbar-burger{align-items:center;background:var(--paper);border:1.4px solid var(--ink);border-radius:8px;color:var(--ink);cursor:pointer;display:none;font-family:inherit;font-size:18px;height:36px;justify-content:center;line-height:1;width:36px}.topbar-scrim{background:#1e1b1673;inset:0;position:fixed;z-index:99}.topbar-sheet{background:var(--paper);border-bottom:1.6px solid var(--ink);box-shadow:0 8px 0 -2px var(--ink),0 14px 24px #1e1b1640;gap:16px;left:0;max-height:calc(100vh - 52px);overflow-y:auto;padding:16px 18px 20px;position:absolute;right:0;top:100%;z-index:100}.sheet-section,.topbar-sheet{display:flex;flex-direction:column}.sheet-section{gap:8px}.sheet-eyebrow{color:var(--ink-faint);font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.sheet-links{display:flex;flex-direction:column;gap:2px}.sheet-links .topbar-nav-link{font-size:14px;justify-content:flex-start;padding:10px 12px;text-align:left;width:100%}.sheet-pills{display:flex;flex-wrap:wrap;gap:6px}@media (max-width:1100px){.topbar-brand-sub{display:none}.topbar-stats{gap:5px}}@media (max-width:880px){.topbar{gap:8px;padding:0 14px}.topbar-nav,.topbar-stats{display:none}.topbar-burger{display:inline-flex}}.ide-container{background:var(--paper-2);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-body--stacked{flex-direction:column}.ide-body--stacked .ide-prompt{border-bottom:1.4px solid var(--ink);flex-shrink:0;height:auto;max-height:45%}.ide-body--stacked .ide-editor-col{flex:1 1;height:auto;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)}.landing{background:radial-gradient(circle at 12% 18%,#e8b4502e,#0000 38%),radial-gradient(circle at 88% 78%,#c45a3a24,#0000 42%),linear-gradient(160deg,var(--paper) 0,var(--paper-2) 100%);color:var(--ink);min-height:100vh;overflow-x:hidden}.landing.landing--in-app{flex:1 1;min-height:0;overflow-y:auto}.landing svg.landing-waves{height:100%;inset:0;opacity:.18;pointer-events:none;position:absolute;width:100%}.landing-nav{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1180px;padding:18px 28px;position:relative;z-index:2}.landing-nav .brand{align-items:center;display:flex;font-size:16px;font-weight:800;gap:8px;letter-spacing:-.02em}.landing-nav .brand-sub{color:var(--ink-soft);font-size:10px;font-style:italic}.landing-nav-actions{align-items:center;display:flex;gap:8px}.landing-hero{grid-gap:40px;align-items:center;display:grid;gap:40px;grid-template-columns:1.05fr .95fr;margin:0 auto;max-width:1100px;padding:40px 28px 72px;position:relative;z-index:1}.landing-hero-copy h1{font-size:56px;font-weight:800;letter-spacing:-.035em;line-height:1.02;margin:0}.landing-hero-copy h1 .accent{background:var(--w-amber);border:1.6px solid var(--ink);border-radius:10px 6px 12px 8px/6px 12px 8px 10px;box-shadow:3px 4px 0 var(--ink);display:inline-block;padding:0 8px;transform:rotate(-1.5deg)}.landing-hero-copy .lead{color:var(--ink-soft);font-size:17px;line-height:1.55;margin:22px 0 12px;max-width:520px}.landing-hero-copy .ctas{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}.landing-hero-copy .ctas .sk-btn{border-radius:12px 8px 14px 9px/8px 14px 9px 12px;font-size:14px;padding:11px 22px}.landing-hero-copy .hero-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}.landing-mascots{align-items:flex-end;display:flex;gap:14px;justify-content:center;min-height:360px;position:relative}.landing-mascot{align-items:center;display:flex;flex-direction:column;height:220px;position:relative;width:200px}.landing-mascot img{display:block;height:100%;width:100%}.landing-mascot.left{animation:floatA 4.2s ease-in-out infinite}.landing-mascot.right{animation:floatB 4.6s ease-in-out infinite}@keyframes floatA{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes floatB{0%,to{transform:translateY(0)}50%{transform:translateY(-14px)}}.landing-mascot .name-tag{background:var(--paper);border:1.4px solid var(--ink);border-radius:18px;bottom:-6px;box-shadow:2px 3px 0 var(--ink);font-size:11px;font-weight:700;padding:3px 10px;position:absolute}.landing-mascot.left .name-tag{transform:rotate(-3deg)}.landing-mascot.right .name-tag{transform:rotate(3deg)}.landing-mascot .speech{background:var(--paper);border:1.4px solid var(--ink);border-radius:12px 8px 14px 9px/8px 14px 9px 12px;box-shadow:2px 3px 0 var(--ink);font-size:11px;font-style:italic;padding:6px 10px;position:absolute;top:-10px;white-space:nowrap}.landing-mascot.left .speech{left:-24px;transform:rotate(-2deg)}.landing-mascot.right .speech{right:-24px;transform:rotate(2deg)}.landing-section{margin:0 auto;max-width:1100px;padding:56px 28px;position:relative;z-index:1}.landing-section .eyebrow{color:var(--ink-faint);font-size:11px;font-weight:700;letter-spacing:.14em;margin-bottom:10px;text-transform:uppercase}.landing-section h2{font-size:30px;font-weight:800;letter-spacing:-.025em;margin:0 0 14px}.landing-section .section-lead{color:var(--ink-soft);font-size:14px;line-height:1.6;margin:0 0 28px;max-width:640px}.philosophy-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(3,1fr)}.philosophy-card{background:var(--paper);padding:22px 22px 20px}.philosophy-card .icon{font-size:24px;margin-bottom:8px}.philosophy-card h3{font-size:15px;font-weight:800;letter-spacing:-.01em;margin:0 0 6px}.philosophy-card p{color:var(--ink-soft);font-size:13px;line-height:1.55;margin:0}.features-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr)}.feature-card{background:var(--paper);display:flex;flex-direction:column;gap:6px;padding:18px}.feature-card .head{align-items:center;display:flex;gap:8px}.feature-card .emoji{align-items:center;background:var(--w-cream);border:1.4px solid var(--ink);border-radius:10px 7px 12px 8px/7px 12px 8px 10px;display:inline-flex;flex-shrink:0;font-size:22px;height:38px;justify-content:center;width:38px}.feature-card.amber .emoji{background:var(--w-amber)}.feature-card.peach .emoji{background:var(--w-peach)}.feature-card.coral .emoji{background:var(--w-coral);color:#fff}.feature-card.tan .emoji{background:var(--w-tan);color:#fff}.feature-card.sky .emoji{background:#cfe4ec}.feature-card h4{font-size:14px;font-weight:800;letter-spacing:-.01em;margin:0}.feature-card p{color:var(--ink-soft);font-size:12.5px;line-height:1.5;margin:4px 0 0}.buddies-row{grid-gap:18px;display:grid;gap:18px;grid-template-columns:1fr 1fr}.buddy-card{align-items:center;background:var(--paper);display:flex;gap:18px;padding:20px}.buddy-card .buddy-portrait{align-items:center;background:var(--paper-2);border:1.4px solid var(--ink);border-radius:12px 8px 14px 9px/8px 14px 9px 12px;display:flex;flex-shrink:0;height:156px;justify-content:center;overflow:hidden;width:140px}.buddy-card.fizz .buddy-portrait{background:#f5e9d0}.buddy-card.buzz .buddy-portrait{background:#f9dcc4}.buddy-card .buddy-portrait img{display:block;height:auto;width:90%}.buddy-card .buddy-meta h3{font-size:22px;font-weight:800;letter-spacing:-.02em;margin:0 0 4px}.buddy-card .buddy-meta .tag{color:var(--ink-soft);font-size:11px;font-style:italic;margin-bottom:10px}.buddy-card .buddy-meta p{color:var(--ink-soft);font-size:13px;line-height:1.5;margin:0}.landing-final-cta{margin:0 auto;max-width:720px;padding:56px 28px 72px;position:relative;text-align:center;z-index:1}.landing-final-cta h2{font-size:28px;font-weight:800;letter-spacing:-.02em;margin:0 0 8px}.landing-final-cta p{color:var(--ink-soft);font-size:14px;margin:0 0 22px}.landing-footer{border-top:1.4px dashed var(--ink);color:var(--ink-faint);font-size:11px;padding:22px;position:relative;text-align:center;z-index:1}@media (max-width:880px){.landing-hero{gap:8px;grid-template-columns:1fr;padding-bottom:40px;padding-top:24px}.landing-hero-copy h1{font-size:42px}.landing-mascots{min-height:280px;order:-1}.landing-mascot{height:170px;width:150px}.buddies-row,.features-grid,.philosophy-grid{grid-template-columns:1fr}.landing-section{padding:40px 20px}}@media (max-width:480px){.landing-hero-copy h1{font-size:34px}.landing-mascots{gap:4px}.landing-mascot{height:150px;width:130px}.landing-mascot .speech{display:none}.landing-nav{padding:14px 18px}}.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.388bd5e8.css.map*/