@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Outfit:wght@500;600;700&display=swap";.tsp-container{max-width:1280px;margin:0 auto;padding:var(--space-6)}.tsp-page-header{background:var(--gradient-primary);border-radius:var(--radius-2xl);padding:var(--space-8) var(--space-8);margin-bottom:var(--space-8);box-shadow:var(--shadow-lg),var(--shadow-glow);position:relative;overflow:hidden}.tsp-page-header:before{content:"";position:absolute;top:-50%;right:-20%;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);border-radius:50%}.tsp-page-header-content{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);position:relative;z-index:1;flex-wrap:wrap}.tsp-page-title{color:#fff;font-size:var(--font-size-3xl);margin:0}.tsp-page-subtitle{color:#fffc;font-size:var(--font-size-sm);margin-top:var(--space-1)}.tsp-page-header-actions{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.tsp-search-box{display:flex;align-items:center;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-full);padding:var(--space-2) var(--space-4);gap:var(--space-2);min-width:240px}.tsp-search-icon{font-size:var(--font-size-sm);opacity:.8}.tsp-search-input{border:none;background:none;outline:none;color:#fff;font-size:var(--font-size-sm);width:100%}.tsp-search-input::placeholder{color:#fff9}.tsp-students-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--space-6)}.tsp-student-card{background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border-light);overflow:hidden;cursor:pointer;transition:all .3s ease;position:relative}.tsp-student-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl),0 0 40px #6366f11f;border-color:var(--color-primary-200)}.tsp-card-accent{height:4px;background:var(--gradient-primary)}.tsp-card-content{padding:var(--space-5) var(--space-6)}.tsp-card-top{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-4)}.tsp-card-avatar{width:52px;height:52px;border-radius:var(--radius-full);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:var(--font-weight-bold);font-size:var(--font-size-lg);flex-shrink:0;overflow:hidden;box-shadow:0 2px 8px #6366f14d}.tsp-card-avatar img{width:100%;height:100%;object-fit:cover}.tsp-card-info{flex:1;min-width:0}.tsp-card-name{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tsp-card-username{font-size:var(--font-size-xs);color:var(--color-text-muted)}.tsp-card-class{display:inline-block;padding:2px 10px;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);background:var(--color-primary-50);color:var(--color-primary-700);border-radius:var(--radius-full);margin-bottom:var(--space-3)}[data-theme=dark] .tsp-card-class{background:#6366f126;color:var(--color-primary-300)}.tsp-card-stats,.tsp-card-stat{margin-bottom:var(--space-3)}.tsp-card-stat-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.tsp-card-stat-label{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-left:var(--space-1)}.tsp-card-progress{width:100%;height:6px;background:var(--color-gray-100);border-radius:var(--radius-full);overflow:hidden;margin-top:var(--space-2)}[data-theme=dark] .tsp-card-progress{background:var(--color-gray-700)}.tsp-card-progress-fill{height:100%;border-radius:var(--radius-full);transition:width .6s ease}.tsp-card-stat-row{display:flex;justify-content:space-between;gap:var(--space-2)}.tsp-card-stat-mini{display:flex;flex-direction:column;align-items:center;flex:1;padding:var(--space-2) 0;background:var(--color-gray-50);border-radius:var(--radius-md)}[data-theme=dark] .tsp-card-stat-mini{background:var(--color-surface-elevated)}.tsp-card-stat-mini-value{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.tsp-card-stat-mini-label{font-size:10px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.tsp-card-footer{padding-top:var(--space-3);border-top:1px solid var(--color-border-light);text-align:center}.tsp-card-view-btn{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-primary-500);transition:color .2s}.tsp-student-card:hover .tsp-card-view-btn{color:var(--color-primary-700)}.tsp-back-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:none;background:var(--color-gray-100);border-radius:var(--radius-full);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all .2s;margin-bottom:var(--space-6)}.tsp-back-btn:hover{background:var(--color-gray-200);color:var(--color-text-primary)}[data-theme=dark] .tsp-back-btn{background:var(--color-surface-elevated)}.tsp-back-icon{font-size:var(--font-size-lg)}.tsp-student-header{display:flex;align-items:center;gap:var(--space-6);padding:var(--space-8);background:var(--color-surface);border-radius:var(--radius-2xl);border:1px solid var(--color-border-light);box-shadow:var(--shadow-md);margin-bottom:var(--space-8);flex-wrap:wrap}.tsp-student-header-avatar{width:80px;height:80px;border-radius:var(--radius-full);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);flex-shrink:0;overflow:hidden;box-shadow:0 4px 15px #6366f14d}.tsp-student-header-avatar img{width:100%;height:100%;object-fit:cover}.tsp-student-header-info{flex:1;min-width:160px}.tsp-student-header-info h2{margin:0 0 var(--space-1);font-size:var(--font-size-2xl)}.tsp-student-username{color:var(--color-text-muted);font-size:var(--font-size-sm)}.tsp-student-header-stats{display:flex;gap:var(--space-6)}.tsp-header-stat{display:flex;flex-direction:column;align-items:center;padding:var(--space-3) var(--space-5);background:var(--color-gray-50);border-radius:var(--radius-lg);min-width:90px}[data-theme=dark] .tsp-header-stat{background:var(--color-surface-elevated)}.tsp-header-stat-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.tsp-header-stat-label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.tsp-section-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-5);padding-left:var(--space-1)}.tsp-attempts-list{display:flex;flex-direction:column;gap:var(--space-3)}.tsp-attempt-card{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);cursor:pointer;transition:all .2s;gap:var(--space-4);position:relative;overflow:hidden}.tsp-attempt-card:hover{transform:translate(4px);box-shadow:var(--shadow-md);border-color:var(--color-primary-200)}.tsp-attempt-score-bar{position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--score-color)}.tsp-attempt-card-left{display:flex;align-items:center;gap:var(--space-4);flex:1;min-width:0;padding-left:var(--space-2)}.tsp-attempt-card-info{display:flex;flex-direction:column;min-width:0}.tsp-attempt-quiz-name{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-size:var(--font-size-base);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tsp-attempt-date{font-size:var(--font-size-xs);color:var(--color-text-muted)}.tsp-attempt-card-right{display:flex;align-items:center;gap:var(--space-4);flex-shrink:0}.tsp-attempt-score{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);min-width:50px;text-align:right}.tsp-attempt-time{font-size:var(--font-size-xs);color:var(--color-text-muted);min-width:50px;text-align:right}.tsp-attempt-arrow{color:var(--color-text-muted);font-size:var(--font-size-lg);transition:transform .2s}.tsp-attempt-card:hover .tsp-attempt-arrow{transform:translate(4px);color:var(--color-primary-500)}.tsp-badge{display:inline-flex;align-items:center;padding:2px 10px;font-size:11px;font-weight:var(--font-weight-semibold);border-radius:var(--radius-full);white-space:nowrap}.tsp-badge-success{background:var(--color-success-50);color:var(--color-success-600)}.tsp-badge-error{background:var(--color-error-50);color:var(--color-error-600)}.tsp-attempt-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-8);background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-2xl);box-shadow:var(--shadow-md);margin-bottom:var(--space-6);gap:var(--space-6);flex-wrap:wrap}.tsp-attempt-header-main h2{margin:0 0 var(--space-3);font-size:var(--font-size-2xl)}.tsp-attempt-meta{display:flex;gap:var(--space-4);align-items:center;flex-wrap:wrap;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.tsp-attempt-score-ring{width:120px;height:120px;position:relative;flex-shrink:0}.tsp-attempt-score-ring svg{width:100%;height:100%;transform:rotate(-90deg)}.tsp-ring-bg{fill:none;stroke:var(--color-gray-100);stroke-width:10}[data-theme=dark] .tsp-ring-bg{stroke:var(--color-gray-700)}.tsp-ring-fill{fill:none;stroke:var(--score-color);stroke-width:10;stroke-linecap:round;transition:stroke-dasharray .8s ease}.tsp-ring-text{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.tsp-ring-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1}.tsp-ring-label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:1px}.tsp-attempt-stats-row{display:flex;gap:var(--space-4);margin-bottom:var(--space-8)}.tsp-mini-stat{flex:1;display:flex;flex-direction:column;align-items:center;padding:var(--space-5);background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-xl)}.tsp-mini-stat-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.tsp-mini-stat-label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:var(--space-1)}.tsp-questions-list{display:flex;flex-direction:column;gap:var(--space-4)}.tsp-question-card{background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border-light);padding:var(--space-5) var(--space-6);transition:all .2s}.tsp-question-correct{border-left:4px solid var(--color-success-500)}.tsp-question-wrong{border-left:4px solid var(--color-error-500)}.tsp-question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3)}.tsp-question-number{font-weight:var(--font-weight-semibold);font-size:var(--font-size-base);color:var(--color-text-primary)}.tsp-question-points{font-size:var(--font-size-sm);color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--space-3)}.tsp-question-time{color:var(--color-text-muted);font-size:var(--font-size-xs)}.tsp-question-text{font-size:var(--font-size-base);color:var(--color-text-primary);margin-bottom:var(--space-4);line-height:var(--line-height-relaxed)}.tsp-answer-comparison{display:flex;flex-direction:column;gap:var(--space-3)}.tsp-answer-box{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-size:var(--font-size-sm)}.tsp-answer-correct{background:var(--color-success-50);border:1px solid rgba(34,197,94,.2)}[data-theme=dark] .tsp-answer-correct{background:#22c55e1a}.tsp-answer-wrong{background:var(--color-error-50);border:1px solid rgba(239,68,68,.2)}[data-theme=dark] .tsp-answer-wrong{background:#ef44441a}.tsp-answer-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary)}.tsp-answer-value{font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.tsp-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-8);gap:var(--space-4)}.tsp-empty-icon{font-size:3rem}.tsp-empty-state p{color:var(--color-text-muted);font-size:var(--font-size-base)}.tsp-loading-center{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16);gap:var(--space-4)}.tsp-loading-center p{color:var(--color-text-muted);font-size:var(--font-size-sm)}.tsp-register-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);animation:fadeIn .2s ease}.tsp-register-modal{background:var(--color-surface);border-radius:var(--radius-2xl);box-shadow:var(--shadow-2xl);width:90%;max-width:460px;animation:slideUp .3s ease}.tsp-register-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--color-border-light)}.tsp-register-header h2{margin:0;font-size:var(--font-size-xl)}.tsp-register-form{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4)}@media(max-width:768px){.tsp-page-header-content{flex-direction:column;align-items:flex-start}.tsp-page-header-actions{width:100%}.tsp-search-box{flex:1;min-width:unset}.tsp-students-grid{grid-template-columns:1fr}.tsp-student-header{flex-direction:column;align-items:flex-start}.tsp-student-header-stats{width:100%;justify-content:space-around}.tsp-attempt-header{flex-direction:column;align-items:flex-start}.tsp-attempt-stats-row{flex-direction:column}.tsp-attempt-card{flex-direction:column;align-items:flex-start}.tsp-attempt-card-right{width:100%;justify-content:space-between;padding-left:var(--space-2)}}:root{--color-primary-50: #eef2ff;--color-primary-100: #e0e7ff;--color-primary-200: #c7d2fe;--color-primary-300: #a5b4fc;--color-primary-400: #818cf8;--color-primary-500: #6366f1;--color-primary-600: #4f46e5;--color-primary-700: #4338ca;--color-primary-800: #3730a3;--color-primary-900: #312e81;--color-secondary-50: #f0fdfa;--color-secondary-100: #ccfbf1;--color-secondary-200: #99f6e4;--color-secondary-300: #5eead4;--color-secondary-400: #2dd4bf;--color-secondary-500: #14b8a6;--color-secondary-600: #0d9488;--color-secondary-700: #0f766e;--color-secondary-800: #115e59;--color-secondary-900: #134e4a;--color-accent-50: #fdf4ff;--color-accent-100: #fae8ff;--color-accent-200: #f5d0fe;--color-accent-300: #f0abfc;--color-accent-400: #e879f9;--color-accent-500: #d946ef;--color-accent-600: #c026d3;--color-accent-700: #a21caf;--color-accent-800: #86198f;--color-accent-900: #701a75;--color-success-50: #f0fdf4;--color-success-500: #22c55e;--color-success-600: #16a34a;--color-warning-50: #fffbeb;--color-warning-500: #f59e0b;--color-warning-600: #d97706;--color-error-50: #fef2f2;--color-error-500: #ef4444;--color-error-600: #dc2626;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--color-background: #f8fafc;--color-surface: #ffffff;--color-surface-elevated: #ffffff;--color-text-primary: #111827;--color-text-secondary: #6b7280;--color-text-muted: #9ca3af;--color-border: #e5e7eb;--color-border-light: #f3f4f6;--gradient-primary: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #a855f7 100%);--gradient-secondary: linear-gradient(135deg, #14b8a6 0%, #06b6d4 100%);--gradient-accent: linear-gradient(135deg, #f43f5e 0%, #ec4899 50%, #d946ef 100%);--gradient-dark: linear-gradient(135deg, #1f2937 0%, #111827 100%);--gradient-glass: linear-gradient(135deg, rgba(255, 255, 255, .1) 0%, rgba(255, 255, 255, .05) 100%);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-family-display: "Outfit", var(--font-family);--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-size-5xl: 3rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--shadow-glow: 0 0 30px rgba(99, 102, 241, .3);--shadow-glow-accent: 0 0 30px rgba(217, 70, 239, .3);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-popover: 600;--z-tooltip: 700;--sidebar-width: 280px;--header-height: 72px;--container-max-width: 1280px}[data-theme=dark]{--color-background: #0f172a;--color-surface: #1e293b;--color-surface-elevated: #334155;--color-text-primary: #f1f5f9;--color-text-secondary: #94a3b8;--color-text-muted: #64748b;--color-border: #334155;--color-border-light: #1e293b;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -2px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4), 0 4px 6px -4px rgba(0, 0, 0, .3)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-background);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-family:var(--font-family-display);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);color:var(--color-text-primary)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}a{color:var(--color-primary-600);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-700)}img{max-width:100%;height:auto}button{font-family:inherit;cursor:pointer}.container{width:100%;max-width:var(--container-max-width);margin:0 auto;padding:0 var(--space-4)}.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-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.text-center{text-align:center}.text-sm{font-size:var(--font-size-sm)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-muted{color:var(--color-text-muted)}.text-secondary{color:var(--color-text-secondary)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);line-height:1;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-md),var(--shadow-glow)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg),var(--shadow-glow)}.btn-secondary{background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-gray-50);border-color:var(--color-gray-300)}.btn-accent{background:var(--gradient-accent);color:#fff;box-shadow:var(--shadow-md),var(--shadow-glow-accent)}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--color-gray-100);color:var(--color-text-primary)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--font-size-base);border-radius:var(--radius-xl)}.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--font-size-xs)}.btn-icon{padding:var(--space-3);border-radius:var(--radius-md)}.card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);overflow:hidden;transition:all var(--transition-normal)}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-header{padding:var(--space-6);border-bottom:1px solid var(--color-border-light)}.card-body{padding:var(--space-6)}.card-footer{padding:var(--space-4) var(--space-6);background:var(--color-gray-50);border-top:1px solid var(--color-border-light)}.card-glass{background:#ffffffb3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.3)}[data-theme=dark] .card-glass{background:#1e293bb3;border:1px solid rgba(255,255,255,.1)}.input-group{display:flex;flex-direction:column;gap:var(--space-2)}.input-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.input{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);outline:none;transition:all var(--transition-fast)}.input:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100)}.input::placeholder{color:var(--color-text-muted)}.input-error{border-color:var(--color-error-500)}.input-error:focus{box-shadow:0 0 0 3px var(--color-error-50)}.error-message{font-size:var(--font-size-sm);color:var(--color-error-500)}.badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);border-radius:var(--radius-full)}.badge-primary{background:var(--color-primary-100);color:var(--color-primary-700)}.badge-success{background:var(--color-success-50);color:var(--color-success-600)}.badge-warning{background:var(--color-warning-50);color:var(--color-warning-600)}.badge-error{background:var(--color-error-50);color:var(--color-error-600)}.badge-secondary{background:var(--color-secondary-100);color:var(--color-secondary-700)}.avatar{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);background:var(--gradient-primary);color:#fff;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);overflow:hidden}.avatar img{width:100%;height:100%;object-fit:cover}.avatar-sm{width:32px;height:32px;font-size:var(--font-size-xs)}.avatar-lg{width:56px;height:56px;font-size:var(--font-size-lg)}.avatar-xl{width:80px;height:80px;font-size:var(--font-size-2xl)}.stat-card{padding:var(--space-6);background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border-light)}.stat-card-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-lg);background:var(--gradient-primary);color:#fff;font-size:var(--font-size-xl);margin-bottom:var(--space-4)}.stat-card-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1}.stat-card-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-2)}.progress{width:100%;height:8px;background:var(--color-gray-200);border-radius:var(--radius-full);overflow:hidden}.progress-bar{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full);transition:width var(--transition-slow)}.spinner{width:40px;height:40px;border:3px solid var(--color-gray-200);border-top-color:var(--color-primary-500);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.spinner-sm{width:24px;height:24px;border-width:2px}.spinner-lg{width:56px;height:56px;border-width:4px}.loading-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:var(--space-4);background:var(--color-background);z-index:var(--z-modal)}.toast{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.toast-success{background:var(--color-success-50);color:var(--color-success-600);border:1px solid var(--color-success-500)}.toast-error{background:var(--color-error-50);color:var(--color-error-600);border:1px solid var(--color-error-500)}.modal-backdrop{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal-backdrop);animation:fadeIn .2s ease}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:500px;max-height:90vh;overflow-y:auto;background:var(--color-surface);border-radius:var(--radius-2xl);box-shadow:var(--shadow-2xl);z-index:var(--z-modal);animation:slideUp .3s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--color-border-light)}.modal-body{padding:var(--space-6)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border-light)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}.dropdown{position:relative;display:inline-block}.dropdown-menu{position:absolute;top:100%;right:0;min-width:200px;padding:var(--space-2);background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);animation:fadeIn .15s ease}.dropdown-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);color:var(--color-text-primary);background:none;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.dropdown-item:hover{background:var(--color-gray-100)}.dropdown-divider{height:1px;margin:var(--space-2) 0;background:var(--color-border-light)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16);text-align:center}.empty-state-icon{font-size:4rem;margin-bottom:var(--space-4);opacity:.5}.empty-state-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-2)}.empty-state-description{color:var(--color-text-secondary);margin-bottom:var(--space-6)}.app-layout{display:flex;min-height:100vh}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background:var(--color-surface);border-right:1px solid var(--color-border-light);display:flex;flex-direction:column;z-index:var(--z-sticky);transition:transform var(--transition-normal)}.sidebar-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-6);border-bottom:1px solid var(--color-border-light)}.sidebar-logo{width:40px;height:40px;background:var(--gradient-primary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:var(--font-weight-bold);font-size:var(--font-size-lg)}.sidebar-title{font-family:var(--font-family-display);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-nav{flex:1;padding:var(--space-4);overflow-y:auto}.nav-section{margin-bottom:var(--space-6)}.nav-section-title{padding:var(--space-2) var(--space-3);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.nav-item:hover{color:var(--color-text-primary);background:var(--color-gray-100)}.nav-item.active{color:var(--color-primary-600);background:var(--color-primary-50)}.nav-item-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh}.header{position:sticky;top:0;height:var(--header-height);padding:0 var(--space-8);background:#f8fafccc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border-light);display:flex;align-items:center;justify-content:space-between;z-index:var(--z-sticky)}[data-theme=dark] .header{background:#0f172acc}.header-left,.header-right{display:flex;align-items:center;gap:var(--space-4)}.header-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold)}.page-content{padding:var(--space-8)}.page-header{margin-bottom:var(--space-8)}.page-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-2)}.page-description{color:var(--color-text-secondary);font-size:var(--font-size-lg)}@media(max-width:1024px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.grid-cols-4{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.header{padding:0 var(--space-4)}.page-content{padding:var(--space-4)}.grid-cols-3,.grid-cols-2{grid-template-columns:1fr}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-bounce{animation:bounce 1s ease-in-out infinite}.animate-slide-in{animation:slideInRight .3s ease-out}.hero-section{position:relative;background:linear-gradient(135deg,#1e3a5f,#2d5a87 30%,#0d9488 70%,#14b8a6);border-radius:var(--radius-2xl);padding:var(--space-12) var(--space-8);margin-bottom:var(--space-8);color:#fff;overflow:hidden}.hero-section:before{content:"";position:absolute;top:-50%;right:-20%;width:60%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);pointer-events:none}.hero-section:after{content:"";position:absolute;bottom:-30%;left:-10%;width:40%;height:150%;background:radial-gradient(circle,rgba(20,184,166,.3) 0%,transparent 60%);pointer-events:none}.hero-content{position:relative;z-index:1}.hero-greeting{font-family:var(--font-family-display);font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-2);line-height:1.2}.hero-subtitle{font-size:var(--font-size-lg);opacity:.9;margin-bottom:var(--space-6);max-width:500px}.hero-search{display:flex;align-items:center;gap:var(--space-3);background:#fffffff2;border-radius:var(--radius-xl);padding:var(--space-2) var(--space-3);max-width:500px;box-shadow:0 10px 40px #0003;margin-bottom:var(--space-6)}.hero-search-icon{color:var(--color-gray-400);font-size:var(--font-size-xl)}.hero-search-input{flex:1;border:none;background:transparent;font-size:var(--font-size-base);color:var(--color-gray-800);outline:none;padding:var(--space-2)}.hero-search-input::placeholder{color:var(--color-gray-400)}.hero-actions{display:flex;gap:var(--space-4);flex-wrap:wrap}.hero-stats{display:flex;gap:var(--space-8);margin-top:var(--space-8);padding-top:var(--space-6);border-top:1px solid rgba(255,255,255,.2)}.hero-stat{text-align:center}.hero-stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold)}.hero-stat-label{font-size:var(--font-size-sm);opacity:.8}.teachers-section{margin-bottom:var(--space-10)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.section-title{font-family:var(--font-family-display);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.section-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.teachers-grid{display:flex;gap:var(--space-6);overflow-x:auto;padding:var(--space-4) var(--space-1);margin:0 calc(var(--space-1) * -1);scrollbar-width:none}.teachers-grid::-webkit-scrollbar{display:none}.teacher-card{flex-shrink:0;display:flex;flex-direction:column;align-items:center;padding:var(--space-6);background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border-light);transition:all var(--transition-normal);cursor:pointer;min-width:160px}.teacher-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl),0 0 40px #6366f126;border-color:var(--color-primary-200)}.teacher-avatar-wrapper{position:relative;margin-bottom:var(--space-4)}.teacher-avatar{width:80px;height:80px;border-radius:50%;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:#fff;border:3px solid white;box-shadow:var(--shadow-lg);overflow:hidden;transition:transform var(--transition-normal)}.teacher-card:hover .teacher-avatar{transform:scale(1.1)}.teacher-avatar img{width:100%;height:100%;object-fit:cover}.teacher-status{position:absolute;bottom:2px;right:2px;width:16px;height:16px;background:var(--color-success-500);border:3px solid white;border-radius:50%}.teacher-name{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-1);text-align:center}.teacher-subject{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:center}.bento-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(2,200px);gap:var(--space-5);margin-bottom:var(--space-10)}.bento-card{position:relative;background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border-light);padding:var(--space-6);overflow:hidden;transition:all var(--transition-normal);cursor:pointer;text-decoration:none;color:inherit;display:flex;flex-direction:column}.bento-card:before{content:"";position:absolute;inset:0;background:var(--card-gradient, transparent);opacity:0;transition:opacity var(--transition-normal)}.bento-card:hover:before{opacity:.05}.bento-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:var(--shadow-xl);border-color:transparent}.bento-card.large{grid-column:span 2;grid-row:span 2}.bento-card.wide{grid-column:span 2}.bento-card.tall{grid-row:span 2}.bento-card.library{--card-gradient: linear-gradient(135deg, #6366f1, #8b5cf6);background:linear-gradient(135deg,#6366f114,#8b5cf60d);border-color:#6366f133}.bento-card.library:hover{background:linear-gradient(135deg,#6366f11f,#8b5cf614)}.bento-card.quizzes{--card-gradient: linear-gradient(135deg, #f43f5e, #ec4899);background:linear-gradient(135deg,#f43f5e14,#ec48990d);border-color:#f43f5e33}.bento-card.quizzes:hover{background:linear-gradient(135deg,#f43f5e1f,#ec489914)}.bento-card.videos{--card-gradient: linear-gradient(135deg, #14b8a6, #06b6d4);background:linear-gradient(135deg,#14b8a614,#06b6d40d);border-color:#14b8a633}.bento-card.videos:hover{background:linear-gradient(135deg,#14b8a61f,#06b6d414)}.bento-card.news{--card-gradient: linear-gradient(135deg, #f59e0b, #f97316);background:linear-gradient(135deg,#f59e0b14,#f973160d);border-color:#f59e0b33}.bento-card.news:hover{background:linear-gradient(135deg,#f59e0b1f,#f9731614)}.bento-card-icon{width:56px;height:56px;border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:1.75rem;margin-bottom:var(--space-4);transition:transform var(--transition-normal)}.bento-card:hover .bento-card-icon{transform:scale(1.1) rotate(-5deg)}.bento-card.library .bento-card-icon{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.bento-card.quizzes .bento-card-icon{background:linear-gradient(135deg,#f43f5e,#ec4899);color:#fff}.bento-card.videos .bento-card-icon{background:linear-gradient(135deg,#14b8a6,#06b6d4);color:#fff}.bento-card.news .bento-card-icon{background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff}.bento-card-title{font-family:var(--font-family-display);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-2)}.bento-card-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);flex:1}.bento-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:var(--space-4)}.bento-card-stat{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary)}.bento-card-arrow{width:32px;height:32px;border-radius:50%;background:var(--color-gray-100);display:flex;align-items:center;justify-content:center;color:var(--color-gray-500);transition:all var(--transition-fast)}.bento-card:hover .bento-card-arrow{background:var(--color-primary-500);color:#fff;transform:translate(4px)}.stats-strip{display:flex;gap:var(--space-4);padding:var(--space-6);background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border-light);margin-bottom:var(--space-10);overflow-x:auto}.stats-strip-item{flex:1;min-width:140px;text-align:center;padding:var(--space-4);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.stats-strip-item:hover{background:var(--color-gray-50)}.stats-strip-icon{font-size:1.5rem;margin-bottom:var(--space-2)}.stats-strip-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-1)}.stats-strip-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.quiz-card-enhanced{position:relative;background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border-light);overflow:hidden;transition:all var(--transition-normal)}.quiz-card-enhanced:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.quiz-card-header{padding:var(--space-5);background:linear-gradient(135deg,#6366f10d,#8b5cf605);border-bottom:1px solid var(--color-border-light)}.quiz-card-body{padding:var(--space-5)}.quiz-card-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-2)}.quiz-card-meta{display:flex;gap:var(--space-4);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.news-preview{display:flex;flex-direction:column;gap:var(--space-3)}.news-preview-item{display:flex;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-lg);transition:background var(--transition-fast)}.news-preview-item:hover{background:#00000008}.news-preview-dot{width:8px;height:8px;border-radius:50%;background:var(--color-primary-500);margin-top:6px;flex-shrink:0}.news-preview-content{flex:1;min-width:0}.news-preview-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.news-preview-date{font-size:var(--font-size-xs);color:var(--color-text-muted)}@media(max-width:1024px){.bento-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:auto}.bento-card.large{grid-column:span 2;grid-row:span 1}.hero-stats{flex-wrap:wrap;gap:var(--space-4)}}@media(max-width:768px){.bento-grid{grid-template-columns:1fr}.bento-card.large,.bento-card.wide{grid-column:span 1}.hero-section{padding:var(--space-8) var(--space-6)}.hero-greeting{font-size:var(--font-size-2xl)}.hero-search{max-width:100%}.hero-stats{gap:var(--space-4)}.hero-stat{flex:1;min-width:80px}.teachers-grid{gap:var(--space-4)}.teacher-card{min-width:140px;padding:var(--space-4)}.teacher-avatar{width:64px;height:64px}.stats-strip{flex-wrap:wrap}.stats-strip-item{min-width:calc(50% - var(--space-2))}}.about-hero{text-align:center;padding:var(--space-16) var(--space-8);background:linear-gradient(135deg,#1e3a5f,#2d5a87,#0d9488);border-radius:var(--radius-2xl);color:#fff;margin-bottom:var(--space-12)}.about-hero-title{font-family:var(--font-family-display);font-size:var(--font-size-5xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-4)}.about-hero-subtitle{font-size:var(--font-size-xl);opacity:.9;max-width:600px;margin:0 auto}.about-features{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-8);margin-bottom:var(--space-12)}.about-feature{text-align:center;padding:var(--space-8);background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border-light);transition:all var(--transition-normal)}.about-feature:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.about-feature-icon{width:64px;height:64px;margin:0 auto var(--space-4);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:2rem;background:var(--gradient-primary);color:#fff}.about-feature-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-2)}.about-feature-description{color:var(--color-text-secondary)}@media(max-width:768px){.about-features{grid-template-columns:1fr}.about-hero{padding:var(--space-10) var(--space-6)}.about-hero-title{font-size:var(--font-size-3xl)}}
