*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;line-height:1.5}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-color:#f8fafc;color:#1a202c;min-height:100vh}[data-theme=dark],[data-theme=dark] body{background-color:#1a202c;color:#f7fafc}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.25;margin-bottom:.5rem}h1{font-size:2.25rem}h2{font-size:1.875rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}p{margin-bottom:1rem}a{color:#3182ce;text-decoration:none;transition:color .2s ease}a:hover{color:#2c5282;text-decoration:underline}[data-theme=dark] a{color:#63b3ed}[data-theme=dark] a:hover{color:#90cdf4}button{font-family:inherit;font-size:inherit;line-height:inherit;cursor:pointer;border:none;background:none;padding:0;margin:0}input,textarea,select{font-family:inherit;font-size:inherit;line-height:inherit;border:1px solid #e2e8f0;border-radius:.375rem;padding:.5rem .75rem;background-color:#fff;color:#1a202c;transition:border-color .2s ease,box-shadow .2s ease}input:focus,textarea:focus,select:focus{outline:none;border-color:#3182ce;box-shadow:0 0 0 3px #3182ce1a}[data-theme=dark] input,[data-theme=dark] textarea,[data-theme=dark] select{background-color:#2d3748;border-color:#4a5568;color:#f7fafc}[data-theme=dark] input:focus,[data-theme=dark] textarea:focus,[data-theme=dark] select:focus{border-color:#63b3ed;box-shadow:0 0 0 3px #63b3ed1a}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.p-2{padding:.5rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.rounded{border-radius:.375rem}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.shadow{box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.shadow-lg{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.shadow-xl{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.typing-word{position:relative;display:inline-block;margin-right:.25rem}.typing-word.correct{background-color:#22c55e1a;color:#16a34a}.typing-word.incorrect{background-color:#ef44441a;color:#dc2626}.typing-word.incorrect .strikethrough{text-decoration:line-through;text-decoration-color:#dc2626}.typing-word .correction,.typing-word .missing{position:absolute;top:-1.5rem;left:0;font-size:.875rem;color:#16a34a;background-color:#22c55e1a;padding:.125rem .25rem;border-radius:.25rem;white-space:nowrap;z-index:10}.typing-word .missing:before{content:"^";margin-right:.125rem}.typing-word .auto-inserted{background-color:#fbbf2433;color:#d97706;animation:flash .5s ease-in-out}@keyframes flash{0%{background-color:#fbbf2466}to{background-color:#22c55e1a}}.spinner{width:2rem;height:2rem;border:2px solid #e2e8f0;border-top:2px solid #3182ce;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.container{padding:0 .5rem}h1{font-size:1.875rem}h2{font-size:1.5rem}h3{font-size:1.25rem}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,a:focus-visible{outline:2px solid #3182ce;outline-offset:2px}[data-theme=dark] button:focus-visible,[data-theme=dark] input:focus-visible,[data-theme=dark] textarea:focus-visible,[data-theme=dark] select:focus-visible,[data-theme=dark] a:focus-visible{outline-color:#63b3ed}@media (prefers-contrast: high){.typing-word.correct{background-color:#22c55e4d;border:1px solid #16a34a}.typing-word.incorrect{background-color:#ef44444d;border:1px solid #dc2626}}
