*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--primary: #4F46E5;--primary-hover: #4338CA;--primary-light: #EEF2FF;--green: #10B981;--green-light: #ECFDF5;--red: #EF4444;--red-light: #FEF2F2;--gray-50: #F9FAFB;--gray-100: #F3F4F6;--gray-200: #E5E7EB;--gray-300: #D1D5DB;--gray-400: #9CA3AF;--gray-500: #6B7280;--gray-600: #4B5563;--gray-700: #374151;--gray-800: #1F2937;--gray-900: #111827;--radius: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow: 0 1px 3px rgba(0, 0, 0, .1), 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07), 0 2px 4px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1), 0 4px 6px rgba(0, 0, 0, .05)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--gray-800);background:var(--gray-50);line-height:1.6;-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none}h1{font-size:1.75rem;font-weight:700;color:var(--gray-900)}h2{font-size:1.35rem;font-weight:600;color:var(--gray-900)}h3{font-size:1.05rem;font-weight:600;color:var(--gray-800)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-family:inherit;font-size:.875rem;font-weight:500;padding:10px 18px;border:1px solid transparent;border-radius:var(--radius);cursor:pointer;transition:all .15s ease}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-ghost{background:transparent;color:var(--gray-600);border-color:var(--gray-200)}.btn-ghost:hover:not(:disabled){background:var(--gray-100);color:var(--gray-800)}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-link{background:none;border:none;color:var(--primary);padding:4px;font-size:.875rem;cursor:pointer}.btn-link:hover{text-decoration:underline}.btn-sm{padding:6px 12px;font-size:.8125rem}.btn-full{width:100%}.badge{display:inline-block;padding:2px 10px;font-size:.75rem;font-weight:500;background:var(--primary-light);color:var(--primary);border-radius:100px}.tag{display:inline-block;padding:4px 12px;font-size:.8125rem;background:var(--gray-100);color:var(--gray-700);border-radius:var(--radius);margin:3px 4px 3px 0}.form-group{display:flex;flex-direction:column;gap:6px;flex:1}.form-group label{font-size:.8125rem;font-weight:500;color:var(--gray-700)}.form-group input,.form-group select,.form-group textarea{font-family:inherit;font-size:.9375rem;padding:10px 12px;border:1px solid var(--gray-300);border-radius:var(--radius);background:#fff;color:var(--gray-800);transition:border-color .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.form-group textarea{resize:vertical}.form-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.form-error{padding:10px 14px;background:var(--red-light);color:var(--red);border-radius:var(--radius);font-size:.875rem;margin-bottom:8px}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px}.navbar{background:#fff;border-bottom:1px solid var(--gray-200);position:sticky;top:0;z-index:50}.navbar-inner{max-width:1200px;margin:0 auto;padding:0 24px;height:56px;display:flex;align-items:center;justify-content:space-between}.navbar-logo{font-size:1.125rem;font-weight:700;color:var(--primary)}.navbar-right{display:flex;align-items:center;gap:16px}.navbar-user{font-size:.875rem;color:var(--gray-500)}.app-content{max-width:1200px;margin:0 auto;padding:24px}.page-center{display:flex;align-items:center;justify-content:center;min-height:60vh}.spinner-container{display:flex;flex-direction:column;align-items:center;gap:16px}.spinner{border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}.spinner-message{color:var(--gray-500);font-size:.875rem}@keyframes spin{to{transform:rotate(360deg)}}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--gray-50);padding:24px}.auth-card{width:100%;max-width:400px;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:40px 32px}.auth-header{text-align:center;margin-bottom:32px}.auth-logo{font-size:1.75rem;color:var(--primary);margin-bottom:8px}.auth-subtitle{color:var(--gray-500);font-size:.9375rem}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-footer{text-align:center;margin-top:20px}.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px}.curriculum-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:box-shadow .15s}.curriculum-card:hover{box-shadow:var(--shadow-md)}.curriculum-card-body{padding:20px 20px 12px;flex:1}.curriculum-card-title{font-size:1.0625rem;font-weight:600;margin-bottom:6px;color:var(--gray-900)}.curriculum-card-desc{font-size:.875rem;color:var(--gray-500);margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.curriculum-card-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.curriculum-card-date{font-size:.75rem;color:var(--gray-400);margin-left:auto}.curriculum-card-actions{padding:12px 20px;border-top:1px solid var(--gray-100);display:flex;gap:8px}.empty-state{text-align:center;padding:80px 24px;color:var(--gray-500)}.empty-state h2{color:var(--gray-700);margin-bottom:8px}.empty-state p{margin-bottom:24px}.create-page{display:flex;justify-content:center;padding-top:16px}.create-card{width:100%;max-width:680px;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:36px 32px}.create-subtitle{color:var(--gray-500);margin-bottom:28px;font-size:.9375rem}.create-form{display:flex;flex-direction:column;gap:20px}.generating-state{text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px}.generating-state h2{color:var(--gray-800)}.generating-state p{color:var(--gray-500);max-width:400px;font-size:.9375rem}.view-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:16px}.view-header-left{display:flex;align-items:flex-start;gap:12px}.view-header-left h1{margin-bottom:4px}.view-description{color:var(--gray-500);font-size:.9375rem;margin-bottom:8px}.view-meta{display:flex;gap:8px;flex-wrap:wrap}.view-objectives,.view-prerequisites{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);padding:16px 20px;margin-bottom:16px}.view-objectives h3,.view-prerequisites h3{margin-bottom:8px}.view-objectives ul,.view-prerequisites ul{padding-left:20px}.view-objectives li,.view-prerequisites li{font-size:.9375rem;color:var(--gray-600);margin-bottom:4px}.view-content{display:grid;grid-template-columns:280px 1fr;gap:20px;min-height:400px}.view-sidebar{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:12px;overflow-y:auto;max-height:calc(100vh - 280px);position:sticky;top:80px}.view-main{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:24px}.module-tree-item{margin-bottom:2px}.module-tree-module{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border:none;background:none;font-family:inherit;font-size:.875rem;font-weight:600;color:var(--gray-700);cursor:pointer;border-radius:var(--radius);text-align:left;transition:background .1s}.module-tree-module:hover{background:var(--gray-100)}.module-tree-module.active{background:var(--primary-light);color:var(--primary)}.module-tree-arrow{font-size:.625rem;transition:transform .15s;flex-shrink:0}.module-tree-arrow.open{transform:rotate(90deg)}.module-tree-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.module-tree-lessons{padding-left:20px}.module-tree-lesson{display:block;width:100%;padding:6px 10px;border:none;background:none;font-family:inherit;font-size:.8125rem;color:var(--gray-600);cursor:pointer;border-radius:var(--radius);text-align:left;transition:background .1s}.module-tree-lesson:hover{background:var(--gray-100)}.module-tree-lesson.active{background:var(--primary-light);color:var(--primary);font-weight:500}.detail-empty{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--gray-400)}.detail-panel h2{margin-bottom:8px}.detail-description{color:var(--gray-500);margin-bottom:16px;font-size:.9375rem}.detail-meta{display:flex;gap:8px;margin-bottom:20px}.detail-section{margin-bottom:24px}.detail-section h3{margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--gray-100)}.detail-section ul,.detail-section ol{padding-left:20px}.detail-section li{font-size:.9375rem;color:var(--gray-600);margin-bottom:4px}.detail-box{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius);padding:14px 16px;font-size:.9375rem;color:var(--gray-700);line-height:1.7;white-space:pre-wrap}.tag-list{display:flex;flex-wrap:wrap;gap:4px}.error-state{text-align:center}.error-state h2{margin-bottom:8px}.error-state p{color:var(--gray-500);margin-bottom:20px}@media (max-width: 768px){.app-content{padding:16px}.form-row,.card-grid,.view-content{grid-template-columns:1fr}.view-sidebar{position:static;max-height:none}.view-header,.view-header-left{flex-direction:column}.auth-card{padding:28px 20px}.create-card{padding:24px 20px}}@media (max-width: 480px){h1{font-size:1.375rem}.curriculum-card-meta{flex-direction:column;align-items:flex-start;gap:4px}.curriculum-card-date{margin-left:0}}
