*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5}.app{display:flex;flex-direction:column;height:100vh;max-width:800px;margin:0 auto;background:#fff;box-shadow:0 0 20px #0000001a}.header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem;text-align:center}.header h1{margin-bottom:.5rem;font-size:1.75rem}.subtitle{opacity:.9;font-size:.95rem}.progress-bar{padding:1rem;background:#fafafa;border-bottom:1px solid #e0e0e0}.progress-info{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.875rem;color:#666;font-weight:500}.progress-track,.mastery-track{height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease}.mastery-fill{height:100%;background:linear-gradient(90deg,#f093fb,#f5576c);transition:width .3s ease}.chat-container{flex:1;display:flex;flex-direction:column;overflow:hidden}.messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1rem}.message{max-width:75%;padding:.875rem 1rem;border-radius:12px;line-height:1.5;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.teacher{align-self:flex-start;background:#f0f0f0;color:#333}.message.student{align-self:flex-end;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.message.loading{padding:1rem}.typing-indicator{display:flex;gap:4px}.typing-indicator span{width:8px;height:8px;background:#999;border-radius:50%;animation:bounce 1.4s infinite ease-in-out both}.typing-indicator span:nth-child(1){animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.hints-container{margin-top:.5rem;padding-top:.5rem;border-top:1px solid #e0e0e0}.hints-toggle{background:none;border:none;color:#667eea;cursor:pointer;font-size:.875rem;font-weight:500;padding:.25rem 0}.hints-toggle:hover{color:#764ba2}.hints{list-style:none;margin-top:.5rem;padding-left:0}.hints li{padding:.5rem;background:#f9f9f9;border-left:3px solid #667eea;margin-bottom:.5rem;border-radius:4px;font-size:.875rem;color:#555}.input-form{display:flex;gap:.5rem;padding:1rem;border-top:1px solid #e0e0e0;background:#fff}.input-field{flex:1;padding:.875rem 1rem;border:1px solid #ddd;border-radius:8px;font-size:1rem;outline:none;transition:border-color .2s}.input-field:focus{border-color:#667eea}.input-field:disabled{background:#f5f5f5;cursor:not-allowed}.send-button{padding:.875rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:opacity .2s}.send-button:hover:not(:disabled){opacity:.9}.send-button:disabled{opacity:.5;cursor:not-allowed}.summary-card{padding:2rem;text-align:center;background:#fafafa;border-top:1px solid #e0e0e0}.summary-card h2{color:#667eea;margin-bottom:1.5rem}.summary-content{text-align:left;background:#fff;padding:1.5rem;border-radius:12px;margin-bottom:1.5rem;box-shadow:0 2px 8px #0000000d}.summary-content p{margin-bottom:1rem;line-height:1.6}.summary-content ul{margin:.5rem 0 1rem 1.5rem}.summary-content li{margin-bottom:.5rem;line-height:1.6}.restart-button{padding:.875rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:opacity .2s}.restart-button:hover{opacity:.9}.selection-container{flex:1;padding:2rem;overflow-y:auto}.selection-step{max-width:600px;margin:0 auto}.selection-step h2{margin-bottom:1.5rem;color:#333;font-size:1.5rem}.selection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.selection-card{padding:1.5rem;background:#fff;border:2px solid #e0e0e0;border-radius:12px;font-size:1rem;font-weight:500;color:#333;cursor:pointer;transition:all .2s;text-align:center}.selection-card:hover{border-color:#667eea;background:#f8f9ff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea26}.back-button{margin-bottom:1rem;padding:.5rem 1rem;background:transparent;border:1px solid #ccc;border-radius:6px;font-size:.9rem;color:#666;cursor:pointer;transition:all .2s}.back-button:hover{background:#f5f5f5;border-color:#999}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;height:100vh}
