:root{--bg: oklch(.975 .006 80);--surface: oklch(.992 .004 80);--surface-2: oklch(.955 .008 80);--ink: oklch(.24 .015 60);--muted: oklch(.52 .012 60);--faint: oklch(.7 .01 65);--line: oklch(.88 .008 70);--accent: oklch(.62 .14 55);--accent-strong: oklch(.54 .15 50);--accent-soft: oklch(.93 .04 70);--done: oklch(.52 .07 150);--font-display: "Fraunces", Georgia, serif;--font-body: "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;--radius: 6px;--measure: 68ch}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font-body);line-height:1.7;font-size:16px;-webkit-font-smoothing:antialiased}a{color:inherit}.btn{font:500 .92rem/1 var(--font-body);border:1px solid transparent;border-radius:var(--radius);padding:.7rem 1.2rem;cursor:pointer;transition:background .18s cubic-bezier(.22,1,.36,1),color .18s}.btn--primary{background:var(--accent);color:#fffbf4}.btn--primary:hover:not(:disabled){background:var(--accent-strong)}.btn--primary:disabled{opacity:.5;cursor:default}.btn--ghost{background:transparent;border-color:var(--line);color:var(--muted)}.btn--ghost:hover{border-color:var(--accent);color:var(--accent-strong)}.state{max-width:30rem;margin:6rem auto;text-align:center;color:var(--muted);font-family:var(--font-mono);font-size:.85rem}.state--error{color:var(--accent-strong)}.gate{min-height:100vh;display:grid;place-items:center;padding:1.5rem}.gate__card{width:100%;max-width:22rem;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:2rem 1.75rem;display:flex;flex-direction:column}.gate__title{font-family:var(--font-display);font-weight:560;font-size:1.9rem;letter-spacing:-.02em;margin:.3rem 0 0}.gate__sub{color:var(--muted);font-size:.9rem;margin:.5rem 0 1.4rem}.gate__card input{border:1px solid var(--line);border-radius:8px;padding:.7rem .8rem;font:400 1rem/1 var(--font-body);background:var(--bg);color:var(--ink);margin-bottom:1rem}.gate__card input:focus-visible{outline:2px solid var(--accent);outline-offset:1px;border-color:transparent}.gate__error{color:var(--accent-strong);font-size:.82rem;margin:0 0 1rem}.page{max-width:52rem;margin:0 auto;padding:clamp(1.5rem,4vw,4rem) 1.25rem 5rem}.kicker{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-strong);margin:0 0 .6rem}.masthead{border-bottom:1px solid var(--line);padding-bottom:2rem;margin-bottom:2.5rem}.masthead__title{font-family:var(--font-display);font-weight:560;letter-spacing:-.025em;font-size:clamp(2.4rem,7vw,3.4rem);line-height:1.02;margin:0}.masthead__sub{color:var(--muted);max-width:38ch;margin:.75rem 0 1.75rem}.overall__bar{height:6px;background:var(--surface-2);border-radius:99px;overflow:hidden}.overall__bar span{display:block;height:100%;background:var(--accent);border-radius:99px;transition:width .6s cubic-bezier(.22,1,.36,1)}.overall__label{font-family:var(--font-mono);font-size:.78rem;color:var(--muted);margin:.7rem 0 0}.overall__label strong{color:var(--ink)}.modules{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1.1rem}.module{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:1.4rem 1.5rem}.module--locked{background:transparent;border-style:dashed;opacity:.72}.module--done{border-color:color-mix(in oklch,var(--done) 35%,var(--line))}.module__head{display:flex;align-items:baseline;gap:1rem}.module__num{font-family:var(--font-display);font-size:1.4rem;color:var(--faint);font-weight:560;min-width:1.8em}.module--done .module__num{color:var(--done)}.module__titles{flex:1}.module__title{font-family:var(--font-display);font-weight:560;font-size:1.3rem;margin:0;letter-spacing:-.01em}.module__sub{color:var(--muted);font-size:.85rem;margin:.1rem 0 0}.module__status{font-family:var(--font-mono);font-size:.72rem;color:var(--muted);white-space:nowrap}.module__desc{color:var(--muted);font-size:.92rem;margin:.9rem 0 0;padding-left:calc(1.8em + 1rem)}.module__hint{font-family:var(--font-mono);font-size:.75rem;color:var(--faint);margin:.8rem 0 0;padding-left:calc(1.8em + 1rem)}.lessons{list-style:none;margin:1.1rem 0 0;padding:0 0 0 calc(1.8em + 1rem);display:flex;flex-direction:column}.lesson__link{display:flex;align-items:center;gap:.8rem;padding:.6rem 0;text-decoration:none;border-top:1px solid var(--line)}.lesson:first-child .lesson__link{border-top:none}.lesson__dot{width:9px;height:9px;border-radius:99px;border:1.5px solid var(--faint);flex:none}.lesson--done .lesson__dot{background:var(--done);border-color:var(--done)}.lesson__title{flex:1;font-size:.95rem}.lesson__link:hover .lesson__title{color:var(--accent-strong)}.lesson__meta{font-family:var(--font-mono);font-size:.72rem;color:var(--faint)}.lesson-view{max-width:78rem;margin:0 auto;padding:clamp(1rem,3vw,2rem) 1.25rem 5rem}.lesson-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.back{text-decoration:none;font-size:.88rem;color:var(--muted)}.back:hover{color:var(--accent-strong)}.lesson-nav__meta{font-family:var(--font-mono);font-size:.72rem;color:var(--faint)}.lesson-grid{display:flex;flex-direction:column;gap:2.5rem}.lesson-head h1{font-family:var(--font-display);font-weight:560;font-size:clamp(1.9rem,5vw,2.7rem);line-height:1.08;letter-spacing:-.02em;margin:0 0 1.5rem}.objectives{background:var(--surface-2);border-radius:8px;padding:1rem 1.25rem}.objectives__label,.exercise__label{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-strong);margin:0 0 .5rem}.objectives ul{margin:0;padding-left:1.1rem}.objectives li{font-size:.9rem;color:var(--ink);margin:.25rem 0}.prose{max-width:var(--measure);margin:2rem 0}.prose h2{font-family:var(--font-display);font-weight:560;font-size:1.45rem;letter-spacing:-.01em;margin:2.4rem 0 .8rem}.prose p{margin:1rem 0}.prose ul,.prose ol{padding-left:1.3rem}.prose li{margin:.4rem 0}.prose strong{font-weight:600}.prose code{font-family:var(--font-mono);font-size:.86em;background:var(--surface-2);padding:.12em .4em;border-radius:4px}.prose blockquote{margin:1.5rem 0;padding:.6rem 1.1rem;background:var(--accent-soft);border-radius:6px;color:var(--ink);font-size:.95rem}.prose blockquote p{margin:.3rem 0}.exercise{border:1.5px solid var(--accent);border-radius:10px;padding:1.3rem 1.5rem;margin:2.5rem 0;background:color-mix(in oklch,var(--accent-soft) 40%,var(--surface))}.exercise__text{margin:0;font-size:1.02rem}.complete{margin-top:2rem}.complete__ok{display:flex;align-items:center;gap:1.2rem;font-family:var(--font-mono);font-size:.85rem;color:var(--done)}.tutor-panel{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:12px;overflow:hidden;height:32rem}.tutor-panel__head{display:flex;gap:.7rem;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--line)}.tutor-panel__dot{width:10px;height:10px;border-radius:99px;background:var(--accent);flex:none}.tutor-panel__name{font-family:var(--font-mono);font-size:.8rem;margin:0;font-weight:500}.tutor-panel__role{font-size:.74rem;color:var(--muted);margin:.1rem 0 0}.tutor-panel__log{flex:1;overflow-y:auto;padding:1.1rem 1.25rem;display:flex;flex-direction:column;gap:.8rem}.tutor-panel__empty{color:var(--muted);font-size:.88rem;margin:auto 0}.bubble{max-width:88%;padding:.65rem .9rem;border-radius:12px;font-size:.92rem;white-space:pre-wrap;line-height:1.55}.bubble--user{align-self:flex-end;background:var(--accent);color:#fffbf4;border-bottom-right-radius:4px}.bubble--assistant{align-self:flex-start;background:var(--surface-2);border-bottom-left-radius:4px}.bubble__typing{color:var(--faint)}.tutor-panel__error{color:var(--accent-strong);font-size:.8rem;margin:0;padding:0 1.25rem}.tutor-panel__form{display:flex;gap:.6rem;padding:.9rem;border-top:1px solid var(--line)}.tutor-panel__form textarea{flex:1;resize:none;border:1px solid var(--line);border-radius:8px;padding:.6rem .7rem;font:400 .9rem/1.4 var(--font-body);background:var(--bg);color:var(--ink)}.tutor-panel__form textarea:focus-visible{outline:2px solid var(--accent);outline-offset:1px;border-color:transparent}@media (min-width: 900px){.lesson-grid{display:grid;grid-template-columns:minmax(0,1fr) 22rem;gap:3rem;align-items:start}.tutor{position:sticky;top:1.5rem}.tutor-panel{height:calc(100vh - 3rem);max-height:44rem}}@media (prefers-reduced-motion: reduce){*{transition:none!important}}
