*{box-sizing:border-box;margin:0;padding:0}body{color:#e0e0e0;background:#0a0a0a;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,monospace}#root{justify-content:center;padding:3rem 1rem;display:flex}.container{width:100%;max-width:640px}h1{color:#fff;margin-bottom:1.5rem;font-size:1.25rem}textarea{color:#e0e0e0;resize:vertical;background:#161616;border:1px solid #333;border-radius:6px;width:100%;height:120px;padding:.75rem;font-family:monospace;font-size:.85rem}textarea:focus{border-color:#555;outline:none}button{color:#0a0a0a;cursor:pointer;background:#fff;border:none;border-radius:6px;padding:.5rem 1.25rem;font-size:.85rem;font-weight:600}button:hover{background:#ddd}button:disabled{opacity:.5;cursor:not-allowed}.result{white-space:pre-wrap;word-break:break-all;background:#161616;border:1px solid #333;border-radius:6px;margin-top:1.5rem;padding:1rem;font-family:monospace;font-size:.8rem}.result.error{color:#f66;border-color:#c33}.result.success{color:#6c6;border-color:#2a7a2a}.exercises{color:#e0e0e0;background:#161616;border:1px solid #2a7a2a;border-radius:6px;margin-top:1rem;padding:1rem;font-family:monospace;font-size:.85rem}.exercises h2{color:#6c6;margin-bottom:.5rem;font-size:.9rem}.exercises ul{padding:0;list-style:none}.exercises li{padding:.2rem 0}.chat-section{border-top:1px solid #333;margin-top:2rem;padding-top:1.5rem}.chat-section h2{color:#fff;margin-bottom:1rem;font-size:1rem}.chat-messages{background:#161616;border:1px solid #333;border-radius:6px;min-height:200px;max-height:400px;margin-bottom:.75rem;padding:1rem;font-size:.85rem;overflow-y:auto}.chat-message{margin-bottom:.75rem;line-height:1.5}.chat-message:last-child{margin-bottom:0}.chat-message .role{margin-right:.5rem;font-weight:600}.chat-message .role.user{color:#7cacf8}.chat-message .role.assistant{color:#6c6}.chat-message .text{white-space:pre-wrap}.chat-input-row{gap:.5rem;display:flex}.chat-input-row input{color:#e0e0e0;background:#161616;border:1px solid #333;border-radius:6px;flex:1;padding:.5rem .75rem;font-family:monospace;font-size:.85rem}.chat-input-row input:focus{border-color:#555;outline:none}.verify-row{margin-top:.75rem}.empty-chat{color:#555;font-style:italic}
