body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background-color:#f8f9fa;color:#212529}.navbar{background-color:#fff;box-shadow:0 2px 4px #0000001a;padding:1rem 0}.nav-container{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;justify-content:space-between;align-items:center}.logo{font-size:1.5rem;font-weight:700;color:#4f46e5;text-decoration:none}.nav-links{display:flex;gap:1rem;align-items:center}.nav-link{color:#6c757d;text-decoration:none;transition:color .2s}.btn{padding:.5rem 1rem;border-radius:.25rem;text-decoration:none;font-weight:500;transition:all .2s}.hero{background-color:#fff;padding:3rem 1rem;text-align:center}.hero-title{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.hero-subtitle{font-size:1.25rem;color:#6c757d;max-width:800px;margin:0 auto 2rem}.courses-section{max-width:1200px;margin:2rem auto;padding:0 1rem}.section-title{font-size:1.75rem;font-weight:700;margin-bottom:2rem}.courses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.course-card{background-color:#fff;border-radius:.5rem;overflow:hidden;box-shadow:0 2px 4px #0000001a;transition:transform .2s,box-shadow .2s}.course-card:hover{transform:translateY(-4px);box-shadow:0 4px 8px #0000001a}.card-content{padding:1.5rem}.card-title{font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.card-description{color:#6c757d;margin-bottom:1rem}.card-meta{display:flex;justify-content:space-between;color:#6c757d;font-size:.875rem;margin-bottom:1rem}.footer{background-color:#343a40;color:#fff;padding:3rem 1rem}.footer-container{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem}.footer-title{font-size:1.25rem;font-weight:600;margin-bottom:1rem}.footer-links{list-style:none;padding:0;margin:0}.footer-link{color:#adb5bd;text-decoration:none;display:block;margin-bottom:.5rem}.footer-link:hover{color:#fff}.spinner{width:3rem;height:3rem;border:4px solid rgba(79,70,229,.3);border-radius:50%;border-top-color:#4f46e5;animation:spin 1s ease-in-out infinite;margin:2rem auto}@keyframes spin{to{transform:rotate(360deg)}}.nav-links{display:flex;gap:16px;align-items:center}.nav-link{color:#6c757d;text-decoration:none;padding:8px 12px;transition:all .2s}.nav-link:hover{color:#4f46e5}.btn-primary{padding:8px 16px;background-color:#4f46e5;color:#fff;border-radius:4px;text-decoration:none;transition:background-color .2s}.nav-btn{padding:8px 16px;border-radius:4px;text-decoration:none;font-weight:500;transition:all .2s;cursor:pointer;border:none;font-size:1rem}.btn-primary{background-color:#4f46e5;color:#fff}.btn-primary:hover{background-color:#4338ca}.btn-logout{background-color:#ef4444;color:#fff}.btn-logout:hover{background-color:#dc2626}.not-found{display:flex;justify-content:center;align-items:center;min-height:60vh;text-align:center;padding:2rem}.not-found-content{max-width:600px;margin:0 auto}.not-found-title{font-size:6rem;font-weight:700;color:#4f46e5;margin:0;line-height:1}.not-found-text{font-size:2rem;font-weight:600;margin:1rem 0}.not-found-subtext{font-size:1.25rem;color:#6c757d;margin-bottom:2rem}.placeholder-section{max-width:1200px;margin:2rem auto;padding:2rem;text-align:center;background-color:#fff;border-radius:.5rem;box-shadow:0 2px 4px #0000001a}.placeholder-title{font-size:2rem;font-weight:700;margin-bottom:1rem}.placeholder-text{font-size:1.25rem;color:#6c757d;margin-bottom:2rem}.auth-container{display:flex;justify-content:center;align-items:center;min-height:70vh;padding:2rem}.auth-card{background-color:#fff;border-radius:.5rem;box-shadow:0 4px 12px #0000001a;padding:2.5rem;width:100%;max-width:500px}.auth-title{font-size:1.75rem;font-weight:600;text-align:center;margin-bottom:2rem;color:#333}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:.95rem;font-weight:500;color:#555}.form-input{padding:.75rem 1rem;border:1px solid #ddd;border-radius:.375rem;font-size:1rem;transition:border-color .2s}.form-input:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 2px #4f46e533}.input-error{border-color:#ef4444}.input-error:focus{box-shadow:0 0 0 2px #ef444433}.error-message{color:#ef4444;font-size:.85rem;margin-top:.25rem}.auth-submit{width:100%;padding:.75rem;font-size:1rem;margin-top:.5rem}.auth-footer{text-align:center;margin-top:1.5rem;color:#666;font-size:.95rem}.auth-link{color:#4f46e5;text-decoration:none;font-weight:500}.auth-link:hover{text-decoration:underline}.auth-error{color:#ef4444;background-color:#fee2e2;padding:.75rem 1rem;border-radius:.375rem;margin-bottom:1.5rem;text-align:center;font-size:.95rem}
