*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #667eea;--primary-dark: #5568d3;--secondary: #764ba2;--success: #43e97b;--danger: #f5576c;--warning: #f093fb;--info: #4facfe;--white: #ffffff;--light: #f8f9fa;--gray-100: #f7fafc;--gray-200: #edf2f7;--gray-300: #e2e8f0;--gray-400: #cbd5e0;--gray-500: #a0aec0;--gray-600: #718096;--gray-700: #4a5568;--gray-800: #2d3748;--gray-900: #1a202c;--dark: #2d3748;--border: #e2e8f0;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-md: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--transition: all .3s cubic-bezier(.4, 0, .2, 1);--transition-fast: all .15s cubic-bezier(.4, 0, .2, 1);--radius-sm: .375rem;--radius: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem}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:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;color:var(--gray-800);line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;color:var(--gray-900)}h1{font-size:2.5rem;margin-bottom:1rem}h2{font-size:2rem;margin-bottom:.875rem}h3{font-size:1.5rem;margin-bottom:.75rem}a{color:var(--primary);text-decoration:none;transition:var(--transition-fast)}a:hover{color:var(--primary-dark)}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--gray-100)}::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}::selection{background-color:var(--primary);color:#fff}*:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.navbar{position:sticky;top:0;z-index:100;background:#ffffffe6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(0,0,0,.08);box-shadow:0 4px 18px #0000000f}.navbar-container{max-width:1400px;margin:0 auto;padding:.9rem 1.75rem;display:flex;align-items:center;justify-content:space-between;gap:1.75rem}.navbar-brand{display:flex;align-items:center;gap:.6rem;text-decoration:none;font-size:1.45rem;font-weight:800;color:#4f46e5;transition:all .25s ease}.navbar-brand:hover{color:#7c3aed;transform:translateY(-1px)}.navbar-links{display:flex;align-items:center;gap:.4rem;flex:1}.nav-link{display:flex;align-items:center;gap:.5rem;padding:.65rem 1.1rem;border-radius:.75rem;text-decoration:none;font-size:.9rem;font-weight:600;color:#4b5563;transition:all .25s ease;white-space:nowrap}.nav-link:hover{background:#eef2ff;color:#4f46e5}.nav-link.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 6px 18px #6366f159}.nav-link.create-button{margin-left:auto;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-weight:700;box-shadow:0 6px 20px #6366f166}.nav-link.create-button:hover{transform:translateY(-2px);box-shadow:0 10px 26px #6366f180}.navbar-user{position:relative}.user-button{display:flex;align-items:center;gap:.6rem;padding:.45rem .9rem;border-radius:9999px;background:#fff;border:2px solid #e5e7eb;cursor:pointer;transition:all .25s ease;font-size:.85rem;font-weight:600;color:#111827}.user-button:hover{border-color:#6366f1;box-shadow:0 4px 14px #6366f133;transform:translateY(-1px)}.user-avatar,.user-avatar-placeholder{width:34px;height:34px;border-radius:50%;flex-shrink:0}.user-avatar{object-fit:cover;border:2px solid #e5e7eb}.user-avatar-placeholder{background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;color:#fff}.user-name{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-menu{position:absolute;top:calc(100% + .6rem);right:0;min-width:260px;background:#fff;border-radius:1rem;box-shadow:0 16px 40px #00000026;border:1px solid #e5e7eb;padding:.75rem;animation:dropdownFade .2s ease-out;z-index:1000}@keyframes dropdownFade{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{padding:.75rem 1rem}.dropdown-user-name{font-weight:700;font-size:.9rem;color:#111827}.dropdown-user-email{font-size:.75rem;color:#6b7280;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-divider{height:1px;background:#e5e7eb;margin:.5rem 0}.dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.7rem 1rem;border-radius:.75rem;border:none;background:transparent;font-size:.85rem;font-weight:600;color:#374151;cursor:pointer;transition:all .2s ease;text-align:left}.dropdown-item:hover{background:#f9fafb}.logout-item{color:#dc2626}.logout-item:hover{background:#fef2f2;color:#b91c1c}@media(max-width:1024px){.navbar-container{padding:.8rem 1.25rem}.user-name{display:none}}@media(max-width:768px){.navbar-container{padding:.7rem 1rem;gap:1rem}.navbar-brand span{display:none}.navbar-links{gap:.25rem}.nav-link span{display:none}.nav-link{padding:.65rem}.nav-link.create-button{margin-left:0}}@media(max-width:480px){.navbar-links{display:none}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2)}.login-container{width:100%;max-width:480px}.login-card{background:#fff;border-radius:var(--radius-xl);padding:3rem;box-shadow:var(--shadow-xl);text-align:center;animation:slideUp .5s cubic-bezier(.4,0,.2,1)}.login-card h1{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem;font-size:2rem}.subtitle{color:var(--gray-600);margin-bottom:2rem;font-size:1.125rem}.login-illustration{margin:2rem 0;display:flex;justify-content:center}.hero-svg{width:200px;height:200px;animation:pulse 3s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.login-button-container{display:flex;justify-content:center;margin:2rem 0}.features{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2.5rem;padding-top:2.5rem;border-top:1px solid var(--border)}.feature{display:flex;flex-direction:column;align-items:center;gap:.5rem;font-size:.875rem;color:var(--gray-600)}.feature-icon{font-size:2rem}@media(max-width:768px){.login-card{padding:2rem}.login-card h1{font-size:1.75rem}.hero-svg{width:150px;height:150px}.features{grid-template-columns:1fr;gap:1rem}}.dashboard-page{min-height:100vh;background:linear-gradient(180deg,#f8fafc,#eef2ff);padding:2.5rem 1.5rem;max-width:1400px;margin:0 auto;animation:fadeIn .5s ease-out}.dashboard-header{background:linear-gradient(135deg,#667eea,#764ba2);padding:2.25rem 2.75rem;border-radius:1.5rem;color:#fff;box-shadow:0 12px 35px #667eea59;margin-bottom:2.5rem}.dashboard-header h1{font-size:2.5rem;font-weight:800;margin-bottom:.25rem}.dashboard-header p{font-size:1.1rem;opacity:.9}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.75rem;margin-bottom:2.75rem}.stat-card{background:#fff;border-radius:1.25rem;padding:1.75rem;box-shadow:0 12px 30px #00000014;display:flex;align-items:center;gap:1.25rem;transition:all .25s ease}.stat-card:hover{transform:translateY(-6px);box-shadow:0 18px 40px #6366f140}.stat-icon{width:56px;height:56px;border-radius:1rem;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.stat-content h3{font-size:2rem;font-weight:800;color:#111827}.stat-content p{font-size:.85rem;color:#6b7280;font-weight:600}.charts-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(420px,1fr));gap:1.75rem;margin-bottom:3rem}.chart-card{background:#fff;padding:1.75rem;border-radius:1.5rem;box-shadow:0 12px 30px #00000014}.chart-card h3{margin-bottom:1rem;font-size:1.25rem;font-weight:700;color:#111827}.recent-goals{background:#fff;border-radius:1.5rem;padding:2.25rem;box-shadow:0 12px 30px #00000014}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.75rem}.section-header h2{font-size:1.75rem;font-weight:800;color:#111827}.goals-preview{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.goal-preview-card{background:#f9fafb;border-radius:1.25rem;padding:1.5rem;display:flex;flex-direction:column;gap:.75rem;text-decoration:none;color:inherit;transition:all .25s ease}.goal-preview-card:hover{background:#fff;transform:translateY(-4px);box-shadow:0 16px 36px #6366f140}.goal-preview-card h3{font-size:1.2rem;font-weight:700;color:#111827;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.goal-preview-card p{font-size:.85rem;color:#6b7280;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.progress-container{display:flex;align-items:center;gap:.75rem}.progress-bar{flex:1;height:8px;background:#e5e7eb;border-radius:9999px;overflow:hidden}.progress-text{font-weight:700;font-size:.8rem;color:#4f46e5;min-width:42px;text-align:right}.view-all{margin-top:2rem;text-align:center}.empty-state{background:#f9fafb;padding:2.5rem;border-radius:1.25rem;text-align:center}@media(max-width:768px){.dashboard-header{padding:2rem}.dashboard-header h1{font-size:2.1rem}.charts-container,.stats-grid,.goals-preview{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start;gap:1rem}}@keyframes riseIn{0%{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.stat-card{animation:riseIn .42s ease-out both}.stat-card:nth-child(1){animation-delay:0ms}.stat-card:nth-child(2){animation-delay:60ms}.stat-card:nth-child(3){animation-delay:.12s}.stat-card:nth-child(4){animation-delay:.18s}.chart-card,.recent-goals{animation:riseIn .52s ease-out both;animation-delay:.22s}@media(prefers-reduced-motion:reduce){.stat-card,.chart-card,.recent-goals{animation:none!important}}.stat-card{background:#fff;border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow);display:flex;align-items:center;gap:1rem}.goals-page{min-height:100vh;background:linear-gradient(180deg,#f8fafc,#eef2ff);padding:2.5rem 1.5rem;max-width:1400px;margin:0 auto;animation:fadeIn .5s ease-out}.goals-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);padding:2.25rem 2.75rem;border-radius:1.5rem;color:#fff;box-shadow:0 12px 35px #667eea59;margin-bottom:2.5rem}.goals-header h1{font-size:2.75rem;font-weight:800;margin:0}.goals-header p{font-size:1.1rem;opacity:.9;margin-top:.25rem}.goals-controls{display:flex;gap:1rem;flex-wrap:wrap;background:#fff;padding:1.5rem;border-radius:1.25rem;box-shadow:0 8px 24px #00000014;margin-bottom:2.5rem}.search-container{flex:1;min-width:260px}.search-input{width:100%;padding:.9rem 1rem;border-radius:.75rem;border:2px solid #e5e7eb;background:#f9fafb;font-size:1rem;transition:.25s ease}.search-input:focus{outline:none;border-color:#6366f1;background:#fff;box-shadow:0 0 0 4px #6366f126}.filter-container{display:flex;align-items:center;gap:.5rem}.filter-select{padding:.9rem 1rem;border-radius:.75rem;border:2px solid #e5e7eb;background:#f9fafb;cursor:pointer;transition:.25s ease}.filter-select:focus{outline:none;border-color:#6366f1;background:#fff;box-shadow:0 0 0 4px #6366f126}.goals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.75rem}.goal-card{background:#fff;border-radius:1.5rem;padding:1.75rem;text-decoration:none;color:inherit;box-shadow:0 12px 30px #00000014;transition:all .3s ease;display:flex;flex-direction:column;gap:1rem}.goal-card:hover{transform:translateY(-6px);box-shadow:0 20px 45px #6366f140}.goal-card-header{display:flex;justify-content:space-between;gap:1rem}.goal-card-header h3{font-size:1.35rem;font-weight:700;color:#111827;margin:0;line-height:1.4}.goal-description{color:#4b5563;font-size:.95rem;line-height:1.6}.goal-meta{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center;border-top:1px solid #e5e7eb;padding-top:.75rem}.category-tag{background:#eef2ff;color:#4338ca;padding:.35rem .85rem;border-radius:9999px;font-size:.7rem;font-weight:700;letter-spacing:.05em}.target-date{font-size:.8rem;color:#6b7280}.goal-progress{margin-top:auto}.progress-info{display:flex;justify-content:space-between;font-size:.85rem;margin-bottom:.35rem}.progress-percentage{font-weight:700;color:#4f46e5}.progress-bar{height:10px;width:100%;background:#e5e7eb;border-radius:9999px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6);transition:width .5s ease}.milestone-count{margin-top:.35rem;font-size:.75rem;color:#6b7280}.status-badge{padding:.35rem .85rem;border-radius:9999px;font-size:.7rem;font-weight:700;text-transform:capitalize}.status-badge.in-progress{background:#f59e0b33;color:#92400e}.status-badge.completed{background:#22c55e33;color:#065f46}.status-badge.not-started{background:#6366f133;color:#3730a3}.status-badge.on-hold{background:#ef444433;color:#991b1b}.loading-container,.empty-state{background:#fff;border-radius:1.5rem;padding:3rem;text-align:center;box-shadow:0 12px 30px #00000014}.spinner{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}@media(max-width:768px){.goals-header{flex-direction:column;padding:2rem}.goals-header h1{font-size:2.2rem}.goals-grid{grid-template-columns:1fr}}.create-goal-page{animation:fadeIn .5s ease-out}.create-goal-container{max-width:800px;margin:0 auto}.create-goal-container h1{color:#fff;text-align:center;margin-bottom:2rem}.progress-indicator{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:2rem}.progress-indicator .step{width:48px;height:48px;border-radius:50%;background:#fff;color:var(--gray-400);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.25rem;transition:var(--transition);box-shadow:var(--shadow)}.progress-indicator .step.active{background:var(--primary);color:#fff;transform:scale(1.1)}.progress-indicator .step.completed{background:var(--success);color:#fff}.form-card{background:#fff;border-radius:var(--radius-xl);padding:2.5rem;box-shadow:var(--shadow-lg);min-height:500px;display:flex;flex-direction:column}.form-step{flex:1;animation:slideUp .3s ease-out}.form-step h2{color:var(--gray-900);margin-bottom:1.5rem}.step-description{color:var(--gray-600);margin-bottom:1.5rem}.milestone-input-group{display:flex;gap:.75rem;margin-bottom:1.5rem}.milestone-input-group .form-input{flex:1}.milestones-list{display:flex;flex-direction:column;gap:.75rem;max-height:300px;overflow-y:auto}.milestone-item{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1rem;background:var(--gray-50);border-radius:var(--radius);border:1px solid var(--border);transition:var(--transition-fast)}.milestone-item:hover{background:var(--gray-100);border-color:var(--gray-300)}.milestone-item span{flex:1;color:var(--gray-700)}.empty-message{text-align:center;color:var(--gray-500);padding:2rem;font-style:italic}.review-section{display:flex;flex-direction:column;gap:1.5rem}.review-item strong{display:block;color:var(--gray-700);margin-bottom:.5rem;font-weight:600}.review-item p{color:var(--gray-600);line-height:1.6}.review-item ul{list-style-position:inside;color:var(--gray-600);line-height:1.8}.form-actions{display:flex;align-items:center;gap:1rem;margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border)}@media(max-width:768px){.form-card{padding:1.5rem}.progress-indicator{gap:.5rem}.progress-indicator .step{width:40px;height:40px;font-size:1rem}.milestone-input-group{flex-direction:column}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}.spacer{display:none}}.goal-detail-page{min-height:100vh;background:linear-gradient(180deg,#f8fafc,#eef2ff);padding:2.5rem 1.5rem;max-width:1400px;margin:0 auto;animation:fadeIn .5s ease-out}.back-button{display:inline-flex;align-items:center;gap:.5rem;background:transparent;border:none;color:#4f46e5;font-weight:600;margin-bottom:1.5rem;cursor:pointer}.back-button:hover{text-decoration:underline}.goal-detail-header{background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem 2.5rem;border-radius:1.5rem;color:#fff;box-shadow:0 12px 35px #667eea59;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:2.5rem}.goal-header-content{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.goal-header-content h1{font-size:2.25rem;font-weight:800;margin:0}.delete-button{display:inline-flex;align-items:center;gap:.5rem;background:#ef444426;color:#fee2e2;border:none;padding:.6rem 1rem;border-radius:.75rem;cursor:pointer;font-weight:600}.delete-button:hover{background:#ef444440}.goal-detail-grid{display:grid;grid-template-columns:2fr 1fr;gap:2rem}.goal-main-content{display:flex;flex-direction:column;gap:2rem}.goal-info-card{background:#fff;border-radius:1.5rem;padding:2rem;box-shadow:0 12px 30px #00000014}.goal-info-card h2{font-size:1.5rem;font-weight:800;margin-bottom:.75rem;color:#111827}.goal-info-card p{color:#4b5563;line-height:1.8}.goal-metadata{display:flex;gap:2rem;margin-top:1.75rem;flex-wrap:wrap}.metadata-item{display:flex;align-items:center;gap:.75rem;color:#6b7280}.metadata-label{font-size:.75rem;font-weight:700;text-transform:uppercase;color:#9ca3af}.metadata-value{font-weight:600;color:#111827}.milestones-card{background:#fff;border-radius:1.5rem;padding:2rem;box-shadow:0 12px 30px #00000014}.milestones-card h2{font-size:1.5rem;font-weight:800;margin-bottom:1.25rem;color:#111827}.add-milestone{display:flex;gap:.75rem;margin-bottom:1.5rem}.milestone-input{flex:1;padding:.75rem 1rem;border-radius:.75rem;border:2px solid #e5e7eb;background:#f9fafb;transition:.25s ease}.milestone-input:focus{outline:none;border-color:#6366f1;background:#fff;box-shadow:0 0 0 4px #6366f126}.milestones-list{display:flex;flex-direction:column;gap:1rem}.milestone-item{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-radius:1rem;background:#f9fafb;border:2px solid #e5e7eb;transition:all .25s ease}.milestone-item:hover{background:#fff;box-shadow:0 10px 25px #00000014}.milestone-item.completed{background:#f0fdf4;border-color:#86efac}.milestone-icon{color:#9ca3af}.milestone-icon.completed{color:#22c55e}.milestone-title{font-weight:600;color:#111827}.goal-sidebar{display:flex;flex-direction:column;gap:2rem}.progress-card{background:#fff;border-radius:1.5rem;padding:2rem;box-shadow:0 12px 30px #00000014;text-align:center}.progress-card h3{font-size:1.25rem;font-weight:800;margin-bottom:1rem;color:#111827}.progress-circle{width:120px;height:120px;margin:0 auto 1rem;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;color:#fff;font-size:2rem;font-weight:800}.progress-bar{height:8px;background:#e5e7eb;border-radius:9999px;overflow:hidden;margin:1rem 0 .5rem}.progress-fill{height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6);transition:width .4s ease}.progress-text{font-size:.85rem;color:#6b7280}.loading-container{background:#fff;border-radius:1.5rem;padding:3rem;box-shadow:0 12px 30px #00000014;text-align:center}@keyframes fadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1024px){.goal-detail-grid{grid-template-columns:1fr}}@media(max-width:768px){.goal-detail-header{padding:2rem}.goal-header-content h1{font-size:1.9rem}.add-milestone{flex-direction:column}}.courses-page{animation:fadeIn .5s ease-out}.courses-header{margin-bottom:2rem;text-align:center}.courses-header h1{color:#fff;margin-bottom:.5rem}.courses-header p{color:#ffffffe6;font-size:1.125rem}.courses-filters{background:#fff;border-radius:var(--radius-xl);padding:1.5rem;box-shadow:var(--shadow);margin-bottom:2rem;display:flex;flex-direction:column;gap:1.5rem}.search-form{display:flex;gap:1rem}.search-input-container{flex:1;position:relative;display:flex;align-items:center}.search-input-container svg{position:absolute;left:1rem;color:var(--gray-400);pointer-events:none}.search-input-container .search-input{padding-left:3rem}.category-filters{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.category-filters svg{color:var(--gray-600)}.category-btn{padding:.5rem 1rem;border:2px solid var(--border);background:#fff;border-radius:var(--radius-full);color:var(--gray-700);font-weight:500;cursor:pointer;transition:var(--transition-fast);font-size:.875rem}.category-btn:hover{border-color:var(--primary);color:var(--primary);background:#667eea0d}.category-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.courses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.course-card{display:flex;flex-direction:column;overflow:hidden;transition:var(--transition);background:#fff}.course-thumbnail{position:relative;width:100%;height:200px;overflow:hidden;background:var(--gray-200)}.course-thumbnail img{width:100%;height:100%;object-fit:cover;transition:var(--transition)}.course-card:hover .course-thumbnail img{transform:scale(1.05)}.course-level{position:absolute;top:1rem;right:1rem;background:#000000b3;color:#fff;padding:.375rem .875rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.course-content{padding:1.5rem;display:flex;flex-direction:column;gap:.75rem;flex:1}.course-content h3{font-size:1.125rem;color:var(--gray-900);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:0}.course-provider{color:var(--gray-600);font-size:.875rem}.course-meta{display:flex;align-items:center;gap:1rem;font-size:.875rem;color:var(--gray-600);padding:.75rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.course-meta .meta-item{display:flex;align-items:center;gap:.375rem}.course-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:.75rem}.course-price{font-weight:700;font-size:1.25rem;color:var(--primary)}@media(max-width:768px){.courses-filters{padding:1rem}.search-form{flex-direction:column}.courses-grid{grid-template-columns:1fr}}@media(max-width:480px){.category-filters{justify-content:center}.category-btn{flex:1;min-width:100px}}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:2rem;max-width:1400px;margin:0 auto;width:100%}.btn-primary,.btn-secondary,.btn-success,.btn-delete,.btn-back,.btn-logout,.btn-add,.btn-remove,.btn-enroll{padding:.75rem 1.5rem;border:none;border-radius:var(--radius);font-size:1rem;font-weight:600;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;white-space:nowrap}.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);color:#fff;box-shadow:var(--shadow)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-secondary{background:#fff;color:var(--primary);border:2px solid var(--primary);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background:var(--primary);color:#fff;box-shadow:var(--shadow)}.btn-success{background:linear-gradient(135deg,var(--success) 0%,#38f9d7 100%);color:#fff;box-shadow:var(--shadow)}.btn-success:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-delete{background:var(--danger);color:#fff;box-shadow:var(--shadow)}.btn-delete:hover{background:#e04c62;transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-back{background:#fff;color:var(--gray-700);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.btn-back:hover{background:var(--gray-100);box-shadow:var(--shadow)}.btn-logout{background:transparent;color:#fff;padding:.5rem;border-radius:var(--radius-full)}.btn-logout:hover{background:#ffffff1a}.btn-add{background:var(--primary);color:#fff;padding:.5rem 1rem}.btn-add:hover{background:var(--primary-dark)}.btn-remove{background:transparent;color:var(--danger);border:none;padding:.25rem .5rem;font-size:1.5rem;line-height:1}.btn-remove:hover{background:var(--gray-100)}.btn-enroll{background:var(--primary);color:#fff;padding:.5rem 1rem;font-size:.875rem}.btn-enroll:hover{background:var(--primary-dark)}.progress-bar{width:100%;height:8px;background:var(--gray-200);border-radius:var(--radius-full);overflow:hidden;position:relative}.progress-bar-large{height:12px}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--secondary));border-radius:var(--radius-full);transition:width .6s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.progress-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.goal-card,.stat-card,.chart-card,.course-card,.goal-preview-card{background:#fff;border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow);transition:var(--transition);cursor:pointer}.goal-card:hover,.goal-preview-card:hover,.course-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.stat-card{cursor:default;display:flex;align-items:center;gap:1rem}.stat-card:hover{transform:translateY(-2px)}.status-badge{padding:.375rem .875rem;border-radius:var(--radius-full);font-size:.875rem;font-weight:600;display:inline-block;text-transform:capitalize}.status-badge.in-progress{background:#fef3c7;color:#92400e}.status-badge.completed{background:#d1fae5;color:#065f46}.status-badge.not-started{background:#e0e7ff;color:#3730a3}.status-badge.on-hold{background:#fee2e2;color:#991b1b}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem}.spinner{width:48px;height:48px;border:4px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading{text-align:center;padding:2rem;color:var(--gray-600)}.empty-state{text-align:center;padding:4rem 2rem;color:var(--gray-600)}.empty-state h3{margin-top:1rem;color:var(--gray-700)}.empty-state p{margin:1rem 0}.empty-state svg{color:var(--gray-400)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .5s cubic-bezier(.4,0,.2,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.slide-up{animation:slideUp .4s cubic-bezier(.4,0,.2,1)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.form-input,.form-textarea,.form-select,.search-input,.milestone-input{width:100%;padding:.75rem 1rem;border:2px solid var(--border);border-radius:var(--radius);font-size:1rem;transition:var(--transition-fast);background:#fff}.form-input:focus,.form-textarea:focus,.form-select:focus,.search-input:focus,.milestone-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #667eea1a}.form-textarea{resize:vertical;min-height:100px}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--gray-700)}.spacer{flex:1}@media(max-width:768px){.main-content{padding:1rem}h1{font-size:2rem}h2{font-size:1.5rem}.btn-primary,.btn-secondary{padding:.625rem 1.25rem;font-size:.875rem}}@media(max-width:480px){h1{font-size:1.75rem}h2{font-size:1.25rem}}
